MySql IN踩过的坑

        private DynamicParameters GetParameters()
        {
            var parameters = new DynamicParameters();
            if (request.ProductId > 0)
            {
                parameters.Add("@ID", request.ProductId);
            }
            else
            {
                parameters.Add("@ID", null);
            }
            if (!string.IsNullOrEmpty(request.ProductName))
            {
                parameters.Add("@Name", string.Format("%{0}%", request.ProductName));
            }
            else
            {
                parameters.Add("@Name", null);
            }

            if (request.FK_StartCitys != null && request.FK_StartCitys.Any())
            {
                parameters.Add("@FK_StartCitys", string.Join(",", request.FK_StartCitys));
            }
            else
            {
                parameters.Add("@FK_StartCitys", null);
            }
            if (request.FK_Areas != null && request.FK_Areas.Any())
            {
                parameters.Add("@FK_Areas", string.Join(",", request.FK_Areas));
            }
            else
            {
                parameters.Add("@FK_Areas", null);
            }
            if (request.FK_DestinationPlays != null && request.FK_DestinationPlays.Any())
            {
                parameters.Add("@FK_DestinationPlays", string.Join(",", request.FK_DestinationPlays));
            }
            else
            {
                parameters.Add("@FK_DestinationPlays", null);
            }
            if (request.Ranks != null && request.Ranks.Any())
            {
                parameters.Add("@Rank", string.Join(",", request.Ranks));
            }
            else
            {
                parameters.Add("@Rank", null);
            }
            DateTime startDate;
            if (!string.IsNullOrEmpty(request.StartDateB) && DateTime.TryParse(request.StartDateB, out startDate))
            {
                parameters.Add("@StartDateB", startDate);
            }
            else
            {
                parameters.Add("@StartDateB", null);
            }

            DateTime endDate;
            if (!string.IsNullOrEmpty(request.StartDateE) && DateTime.TryParse(request.StartDateE, out endDate))
            {
                endDate = endDate.AddDays(1).AddMilliseconds(-1);
                parameters.Add("@StartDateE", endDate);
            }
            else
            {
                parameters.Add("@StartDateE", null);
            }
            return parameters;
        }

        private string GetWhereExt()
        {
            var whereExt = string.Empty;
           
            if (request.FK_DestinationPlays != null && request.FK_DestinationPlays.Any())
            {

                whereExt += string.Format(" AND pext.FK_DestinationPlay IN ({0}) ", string.Join(",", request.FK_DestinationPlays));
            }
            return whereExt;
        }
SELECT COUNT(1) FROM
(SELECT p.ID
FROM product p
LEFT JOIN productext pext ON pext.FK_Product=p.ID
LEFT JOIN rank r ON r.ID = pext.FK_Rank
LEFT JOIN productsalescity sc ON sc.FK_Product=p.ID AND sc.IsValid='T'
INNER JOIN tour t ON t.FK_Product=p.ID AND t.IsValid='T' AND t.IsShowH5='T' AND t.CanBooking='T'
	AND t.ExpireDate>=NOW() AND t.DeadLineDate>= NOW() AND t.`Status`=2 AND IFNULL(t.IsLock,'F')<>'T'
LEFT JOIN tourminpriceinventory tmpi ON tmpi.FK_Tour=t.ID
WHERE p.IsValid='T' AND p.Category IN (1,2,3)
AND p.ID=IFNULL(@ID,p.ID)
AND p.name LIKE IFNULL(@Name,p.name)
AND IFNULL(pext.FK_DestinationPlay,0) IN (IFNULL(@FK_DestinationPlays,IFNULL(pext.FK_DestinationPlay,0)))
AND IFNULL(pext.FK_Rank,0) IN (IFNULL(@Rank,IFNULL(pext.FK_Rank,0)))
AND IFNULL(sc.FK_City,0) IN (IFNULL(@FK_StartCitys,IFNULL(sc.FK_City,0)))
AND IFNULL(p.FK_Area,0) IN (IFNULL(@FK_Areas,IFNULL(p.FK_Area,0)))
AND t.StartDate >= IFNULL(@StartDateB,t.StartDate)
AND t.StartDate <= IFNULL(@StartDateE,t.StartDate)
#{0}
GROUP BY p.ID
) AS A;

变量@FK_DestinationPlays的值为:194,195,196,197,198,199,200,201,202,203,204,205,206,207,208,209,210,211,212,213,214,215,216,217,218,306,307,308,309,349,377

其他变量均为null;

当采用写法:AND IFNULL(pext.FK_DestinationPlay,0) IN (IFNULL(@FK_DestinationPlays,IFNULL(pext.FK_DestinationPlay,0)))

时,会自动将变量值添加引号,造成仅匹配到FK_DestinationPlay为194的数据,造成sql查询结果不准确;正确写法为调用方法GetWhereExt,即:

AND pext.FK_DestinationPlay IN (194,195,196,197,198,199,200,201,202,203,204,205,206,207,208,209,210,211,212,213,214,215,216,217,218,306,307,308,309,349,377)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL中,IN是一个用于查询的关键字,它用于在一个字段中匹配给定的多个值。例如,使用IN关键字可以通过以下方式查询数据:SELECT * FROM table_name WHERE field_name IN (value1, value2, value3, ...)。这将返回字段中匹配任何一个给定值的行。 另外,如果你想要查询不在指定值列表中的数据,可以使用NOT IN关键字。例如:SELECT * FROM table_name WHERE field_name NOT IN (value1, value2, value3, ...)。这将返回字段中不匹配任何一个给定值的行。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品 MySQL 是最流行的关系](https://download.csdn.net/download/weixin_43055264/88265268)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [mysql中in的用法](https://blog.csdn.net/yihanzhi/article/details/81065573)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值