gpt4 book ai didi

c# - Dapper 带有 sql 查询动态参数

转载 作者:行者123 更新时间:2023-12-02 04:30:18 24 4
gpt4 key购买 nike

在我的 asp.net web-api 中,从下面的代码片段中收到错误“ORA-00936:缺少表达式”。我尝试了很多解决方案,但没有克服这个错误。我还想知道如何动态绑定(bind)多个参数。我使用 oracle 作为我的后端,并使用 dapper 作为我的 ORM。

        string empId = json.EMPID; //'15RD005'

var sql = @"Select id_no,SNO,REASON,APPLIEDDATE,Case
when LEAVE_TYPE = 0 then 'CL'
when LEAVE_TYPE = 1 then 'EL'
when LEAVE_TYPE = 2 then 'SL'
when LEAVE_TYPE = 3 then 'OFF'
when LEAVE_TYPE = 4 then 'OD-OFF'
when LEAVE_TYPE = 5 then 'LOP'
when LEAVE_TYPE = 6 then 'OPTIONAL' end LEAVE_TYPE,
to_char(fromdate,'DD-MON-YYYY') f_date, to_char(todate,'DD-MON-YYYY') t_date,
Case when fromslot=0 then 'First-Half' when fromslot=1 then 'Second-Half' when fromslot=2 then 'Full-Day' end From_Slot,
Case when toslot=0 then 'First-Half' when toslot=1 then 'Second-Half' when toslot=2 then 'Full-Day' end To_Slot,
applieddays APP_DAYS,
case when actinact=0 and cancel_idno is not null then 'Cancelled'
when actinact=1 and AUTH_IDNO is null then 'Pending'
when actinact=0 and cancel_idno is not null then 'Rejected'
else 'Authorised' end leave_Status
from Tleaves where to_char(Todate,'mm-yyyy') >= to_char(sysdate-30,'mm-yyyy') and to_char(todate,'mm-yyyy') <=to_char(sysdate,'mm-yyyy')
and to_char(Todate,'yyyy')=to_char(sysdate,'yyyy') and id_no like @EmpId Order by sno";



try
{
using (OracleConnection db = new OracleConnection(conString))
{
db.Open();

var pastLeavesReport = new PastLeavesReportDTO();
//3.Present and last month lev status report
List<PastLeavesReportInfoDTO> pastLeavesReportInfo = db.Query<PastLeavesReportInfoDTO>(sql, new { EmpId = empId }).ToList();

pastLeavesReport.EMPID = "";
pastLeavesReport.LEAVES = pastLeavesReportInfo;


return Ok(
new EmpLeavesActionResponse(ActionStatusCodes.PastLeavesReportDataFound,
"",
pastLeavesReport));


}
}
catch (Exception exp)
{

return Ok(
new EmpLeavesActionResponse(ActionStatusCodes.ServerException,
exp.Message,
null));

}

最佳答案

最后我解决了我的问题,对我的代码做了很少的改变。即@Empid改为:Empid,因为oracle数据库支持这种方式的动态参数。对于我的第二个问题,即如何处理多个动态参数,我使用 dappers DynamicParameters 类,如下所示,

        var parameters = new Dictionary<string, object>();
parameters.Add("ID", empId);

DynamicParameters dbParams = new DynamicParameters();
dbParams.AddDynamicParams(parameters);

我们可以在 dapper 中使用它,如下面的代码片段所示,参数查询是一个示例sql查询。

          dynamic result = db.Query(query, dbParams);

关于c# - Dapper 带有 sql 查询动态参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43412455/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com