zoukankan      html  css  js  c++  java
  • SQlserver 当输入参数为可选条件

    以前很懒,都是用拼接字符串的方式,加上if 语句,根据输入参数是否为空来判断是否需要在where 后加上对应字段的条件限制

    但是拼接字符串很烦,又总是被转义符搞得很烦  ''''

    所以想了其他办法

    分三种情况(varchar,int,date)都尝试了一下

    使用case when 和通配符当主角,而不是'''''''''

    不难理解,怕隔天忘记所以记一笔

    alter proc sp_testParam
    (
       @name varchar(50),
       @ID int,
       @sDate date,
       @eDate date
    )
    as
    begin

    --懒得要死,老是不乐意去记默认值,所以打印出来望自己长点脑子

    print @name+'--name'
    print cast(@ID as varchar(50))+'--ID'
    print cast(@sDate as varchar(50))+'--sDate'
    print cast(@eDate as varchar(50))+'--eDate'

    select * from benInfo
    where
    --varchar,使用'%%'表示包含任何字符串
    name like case when @name is null or @name='' then '%%' else '%'+@name+'%' end 
    --int,使用'[0-9]%'表示包含任何数字,因为该字段是ID,不需要模糊查询,则不需加通配符,完全匹配
    and cast(ID as varchar(50)) like case when @ID is null or @ID=0 then '[0-9]%' else cast(@ID as varchar(50)) end
    --date,该类型的默认值是'1900-01-01',因此起始日期不用理会,结束日期判断一下,未填则给无限大
    and currentDate between @sDate and case when @eDate is null or @eDate='1900-01-01'

     then '9999-12-31' else @eDate end


    end

    --exec sp_testParam '','','','2010-09-03'

    至此尝试了一下,在解决简单逻辑时,此方法是可行的

    /*
    PS.
    1.意外发现,当 like 后的字符串里不带有通配符时,其作用等同于等号 =

      

    */

  • 相关阅读:
    Spring__SpringMVC__Mybatis整合
    Mybatis__延迟加载
    mybatis__关联关系__1对1,1对多
    动态SQL基本语句用法
    log4j的使用 && slf4j简单介绍
    Mybatis接口与映射文件
    ORM简介 && MyBatis和Hibernate的不同 && 动态代理简单实现Mybatis基本使用
    20169207《linux内核原理与分析》第二周作业
    关于Linux学习中的问题和体会
    [algothrim]URL相似度计算的思考
  • 原文地址:https://www.cnblogs.com/xcxcxcxc/p/5541183.html
Copyright © 2011-2022 走看看