首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在实体框架中编写参数化的where-in原始sql查询

如何在实体框架中编写参数化的where-in原始sql查询
EN

Stack Overflow用户
提问于 2014-08-26 08:41:17
回答 3查看 19.9K关注 0票数 22

如何在Entity Framework中编写参数化的where-in原始sql查询?我尝试过以下几种方法:

代码语言:javascript
复制
string dateQueryString = String.Join(",", chartModelData.GetFormattedDateList());
//Dates returned in format of 20140402,20140506,20140704

const string selectQuery = 
    @"SELECT 
         MAX(DATA_SEQ) AS MaxSeq, MIN(DATA_SEQ) AS MinSeq, COUNT(1) AS TotSampleCnt
      FROM SPCDATA_TB
      WHERE DATA_WDATE IN @DateParam  
      AND LINE_CODE = @LineCode
      AND MODEL_NO = @ModelNumber
      AND LOT_NO = @LotNumber
      AND EQUIP_NO LIKE @EquipNumber";

SPCDataSeqCntInfo dataSeqCntInfo = _dbContext.Database.SqlQuery<SPCDataSeqCntInfo>(
      selectQuery,
      new SqlParameter("@DateParam",   dateQueryString),
      new SqlParameter("@LineCode",    chartModelData.LineCode),
      new SqlParameter("@ModelNumber", chartModelData.ModelNum),
      new SqlParameter("@EquipNumber", equipmentNumber),
      new SqlParameter("@LotNumber",   chartModelData.LotNum)
  ).SingleOrDefault() ?? new SPCDataSeqCntInfo();

但不出所料,它在DateParam上抛出一个错误,因为它需要单个值。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-08-26 11:06:17

这不是实体框架所特有的问题,您可以通过动态生成自己的参数名来解决它。

代码语言:javascript
复制
var parameters = new List<SqlParameter> {
    new SqlParameter("@DateParam", dateQueryString),
    new SqlParameter("@LineCode", chartModelData.LineCode),
    new SqlParameter("@ModelNumber", chartModelData.ModelNum),
    new SqlParameter("@EquipNumber", equipmentNumber),
    new SqlParameter("@LotNumber", chartModelData.LotNum)   
};

var dateParameters = chartModelData
    .GetFormattedDateList()
    .Select((date, index) => new SqlParameter("@date" + index, date));
    .ToList();

parameters.AddRange(dateParameters);
    
var inValues = string.Join(", ", dateParameters.Select(p => p.ParameterName));

var query = @"SELECT MAX(DATA_SEQ) AS MaxSeq, 
   MIN(DATA_SEQ) AS MinSeq, 
   COUNT(1) AS TotSampleCnt
   FROM SPCDATA_TB
   WHERE DATA_WDATE IN (" + inValues + @")  
   AND LINE_CODE = @LineCode
   AND MODEL_NO = @ModelNumber
   AND LOT_NO = @LotNumber
   AND EQUIP_NO LIKE @EquipNumber";

var myResult = _dbContext.Database
    .SqlQuery<SPCDataSeqCntInfo>(query, parameters.ToArray());

发送到SQL-Server的查询结果如下所示:

代码语言:javascript
复制
SELECT 
   MAX(DATA_SEQ) AS MaxSeq, 
   MIN(DATA_SEQ) AS MinSeq, 
   COUNT(1) AS TotSampleCnt
FROM SPCDATA_TB
WHERE DATA_WDATE IN (@date0, @date1, @date2)  
AND LINE_CODE = @LineCode
AND MODEL_NO = @ModelNumber
AND LOT_NO = @LotNumber
AND EQUIP_NO LIKE @EquipNumber

通常,您希望在编写查询时避免进行字符串操作,但是,我相信这个示例是安全的,不会被sql注入。

票数 32
EN

Stack Overflow用户

发布于 2014-08-26 09:21:33

下面是如何用SQL编写查询。

代码语言:javascript
复制
select *
    from MyTable
    where dateColumn in ('2014-01-01', '2014-02-01', '2014-03-01')

因此,除了必须表示这个完全由圆括号分隔的字符串之外,不应该有其他的期望。

代码语言:javascript
复制
var dateQueryString = string.Join(",", chartModelData.GetFormattedDateList());
// Dates shall be returned as DateTime.ToShortDateTimeString() as follows:
// '2014-01-01', '2014-02-01', '2014-03-01'

然后只剩下用括号把它括起来。

代码语言:javascript
复制
var sql = @"select max(data_seq)    as MaxSeq
                    , min(data_seq) as MinSeq
                    , count(1)      as TotSampleCnt
                from spcdata_tb
                where data_wadate in (@DateParam)
                    and line_code  =  @LineCode
                    and model_no   =  @ModelNumber
                    and lot_no     =  @LotNumber
                    and equip_no like @EquipNumber";

为每个命名参数提供参数值,瞧!这样就可以了!

票数 1
EN

Stack Overflow用户

发布于 2014-08-26 09:01:04

我将编写一个存储的proc,它接受您的参数,然后将proc添加到您的edmx。

然后,在edmx ->模型浏览器中,->函数导入-> ...将存储的proc的返回类型更改为SPCDataSeqCntInfo。

然后实体框架将负责传递您的参数。

例如:

代码语言:javascript
复制
public static List<SPCDataSeqCntInfo> GetSPCDataSeqCntInfo(DateTime dateParam, string lineCode, int modelNum, int equipmentNumber, int lotNum)
{
    using (var db = new NameOfMyEntites())
    {
        return db.sp_GetSPCDataSeqCntInfo(dateParam, lineCode, modelNum, equipmentNumber, lotNum).ToList();
    }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25496357

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档