问题1: 存储过程中定义变量不赋值的时候,各类型的默认值是什么
@declare @var1 int
@declare @var2 nvarchar(50)
@declare @var3 date不赋值的情况下,以上各变量的默认值是什么?假设 select @var1=field1,@var2=field2,@var3=field3 from tablename where false --也就是当条件不满足返回空行的时候,这三个变量的值又是什么?问题2:模糊查询条件带变量的时候怎么实现?
select * from tablename where field like '%@var%' --这里@var是个变量,通配符内有个变量,如果这样写,变量当然会当成字符串。要实现这样带变量的模糊查询该怎么写?问题3:sqlserver中有没有判断字符串是否等于空字符串或者null的函数,
如果要判断一个变量不为null值是这样写吗:if @var<>null
如果是判断一个字符串是否为空字符串怎么写?if @var='' 还是有其他的办法?问题4:sqlserver中要将时间类型当参数或者条件,该时间类型又不为变量不依赖程序传值的时候怎么传,比如:
select * from tablename where thetime>'2011-11-6 11:40:16' 是当字符串还是其他的什么?

解决方案 »

  1.   

    问题1: 存储过程中定义变量不赋值的时候,各类型的默认值是什么
    @declare @var1 int
    @declare @var2 nvarchar(50)
    @declare @var3 date不赋值的情况下,以上各变量的默认值是什么?
    ------------
    null--空值 
      

  2.   

     select @var1=field1,@var2=field2,@var3=field3 from tablename where false ---等于没赋值前的值问题2:模糊查询条件带变量的时候怎么实现?
    select * from tablename where field like '%'+@var+'%'
      

  3.   

    问题3:sqlserver中有没有判断字符串是否等于空字符串或者null的函数,
    如果要判断一个变量不为null值是这样写吗:if @var<>null用if @var is not nullif @var=''--这样就行了,简单 nullif(@var,'') is null--这个定有点多余
      

  4.   

    select * from tablename where thetime>'2011-11-6 11:40:16'--这是日期日期类型 > 字符类型 比较时隐性转换为日期
      

  5.   


    用 convert(varchar(19),日期列,120)--取19个字符,格式为120
      

  6.   

    参照联机日期转字符格式
    http://technet.microsoft.com/zh-cn/library/ms187928(SQL.90).aspx