SOS:sqlserver的若干菜鸟问题
时间:2011-11-06
来源:互联网
@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' 是当字符串还是其他的什么?
作者: zq2it 发布时间: 2011-11-06
@declare @var1 int
@declare @var2 nvarchar(50)
@declare @var3 date
不赋值的情况下,以上各变量的默认值是什么?
------------
null--空值
作者: roy_88 发布时间: 2011-11-06
作者: ssp2009 发布时间: 2011-11-06
select @var1=field1,@var2=field2,@var3=field3 from tablename where false ---等于没赋值前的值 问题2:模糊查询条件带变量的时候怎么实现? select * from tablename where field like '%'+@var+'%'
作者: roy_88 发布时间: 2011-11-06
如果要判断一个变量不为null值是这样写吗:if @var<>null
用if @var is not null
if @var=''--这样就行了,简单 nullif(@var,'') is null--这个定有点多余
作者: roy_88 发布时间: 2011-11-06
--这是日期
日期类型 > 字符类型 比较时隐性转换为日期
作者: roy_88 发布时间: 2011-11-06
select * from tablename where thetime>'2011-11-6 11:40:16'
--这是日期
日期类型 > 字符类型 比较时隐性转换为日期
那如果我要测试的时候是把时间写成字符串类型吗?谢谢了
作者: zq2it 发布时间: 2011-11-06
引用 5 楼 roy_88 的回复:
select * from tablename where thetime>'2011-11-6 11:40:16'
--这是日期
日期类型 > 字符类型 比较时隐性转换为日期
那如果我要测试的时候是把时间写成字符串类型吗?谢谢了
用 convert(varchar(19),日期列,120)--取19个字符,格式为120
作者: roy_88 发布时间: 2011-11-06
作者: roy_88 发布时间: 2011-11-06
热门阅读
-
office 2019专业增强版最新2021版激活秘钥/序列号/激活码推荐 附激活工具
阅读:74
-
如何安装mysql8.0
阅读:31
-
Word快速设置标题样式步骤详解
阅读:28
-
20+道必知必会的Vue面试题(附答案解析)
阅读:37
-
HTML如何制作表单
阅读:22
-
百词斩可以改天数吗?当然可以,4个步骤轻松修改天数!
阅读:31
-
ET文件格式和XLS格式文件之间如何转化?
阅读:24
-
react和vue的区别及优缺点是什么
阅读:121
-
支付宝人脸识别如何关闭?
阅读:21
-
腾讯微云怎么修改照片或视频备份路径?
阅读:28