sqlserver中的字符串(含有变量的字符串连接)总结.docx

上传人:jian****018 文档编号:9440244 上传时间:2020-04-05 格式:DOCX 页数:2 大小:44.69KB
返回 下载 相关 举报
sqlserver中的字符串(含有变量的字符串连接)总结.docx_第1页
第1页 / 共2页
sqlserver中的字符串(含有变量的字符串连接)总结.docx_第2页
第2页 / 共2页
亲,该文档总共2页,全部预览完了,如果喜欢就下载吧!
资源描述
sqlserver 中的字符串(含有变量的字符串连接)总结1. 首先说明一下单引号和说引号的区别(1)单引号:在SQL语句中用于表达一个字符串(双引号不能表达)如:declare str Nvarchar(200) set str=selecT *from sys.databases如果写成set str=”selecT *from sys.databases”就会报错。还有就是在向表中插入数据的时候,是字符串类型的字段,在values里面都得加上单引号,但是数值int型的数据可加可不加单引号插入数据。注意:日期类型也要加引号如:insert into #tmp values(张三,男,23)=insert into #tmp values(张三,男,23)(2)双引号:在SqlServer中主要用于对单引号的转义如:set str=selecT *from sys.databases where name=”master”这是因为需要表达出master,但是外面已经有一层单引号了,如果不写成”master”,继续写成selecT *from sys.databases where name=master就会出现第1个单引号和第2个单引号匹配,而不是我们想的和第4个匹配,这样就出现了匹配错误。所以我们用双引号来转义成单引号。(3)字符串的连接符+是连接运算符,它可以将两个字符串连接成一个字符串。eg:a=abc + def执行连接运算后,a=abcdef。再如a=abc + temp注意,这里temp是一个字符串变量,假如temp=def,那么代入上面的式子,则结果为:a=abc + def继续执行连接运算,结果a=abcdef。有时候,可能会有多个连接运算符,只要依次运算即可。如a=abc + def+& gh,结果a=abcdefgh注意:字符串常量两边一定要加单引号,表示这是一个字符串。如上面的abc、def、gh两边的双引号就都是表示这是一个字符串。但是字符串变量名称两边不能再加双引号了,如上面提到的a=abc + temp 中的temp是变量,所以两边不能加双引号。如果给temp加上双引号,那么它就变成了一个字符串常量temp了。(4)含有变量的字符串拼接由于变量不能直接写入字符串,故必须通过连接符+和字符串常量连接在一起,所以写法有些变化。主要有两种写法:法1:整个字符串不分割Create Procedure TestTestID intAsDeclare s nvarchar(800) Set s=Select * From dbo.Categories where CategoryID=+cast(TestID as varchar)+print sexec(s)exec Test TestID=1注意:执行时存在类型转换错误(int型和varchar拼接时会出错误),则应用相应的类型转换函数,对变量进行类型转换(如cast()函数)。下面着重理解此条语句的写法:(为什么会出现3引号,4引号?)s=Select * From dbo.Categories where CategoryID=+cast(TestID as varchar)+实际上面语句可以分为3个部分:字符串常量s1:Select * From dbo.Categories where CategoryID=含有变量的部分s2:cast(TestID as varchar)字符串常量s3:现在假设TestID=1,那么cast(TestID as varchar)=1我们先把s1和s2连接起来(两个字符串之间的两个单引号被合并丢弃),结果变为Select * From dbo.Categories where CategoryID=1+s3再把s1+s2和s3萍姐起来,就变成Select * From dbo.Categories where CategoryID=1print之后的结果就变成:Select * From dbo.Categories where CategoryID=1正是我们想要的结果。注意双引号被转义成单引号了。法2:字符串分割Set s=Select * From dbo.Categories where CategoryID=+cast(TestID as varchar)+分析:实际上上面可以分成四部分字符串常量s1:Select * From dbo.Categories where CategoryID=字符串常量s2:含有变量的部分s3:cast(TestID as varchar)字符串常量s4:现在假设TestID=2, 那么cast(TestID as varchar)=2s1和s2拼接结果:Select * From dbo.Categories where CategoryID=s1+s2和s3拼接结果:Select * From dbo.Categories where CategoryID=2s1+s2+s3和s4的拼接结果:Select * From dbo.Categories where CategoryID=2print打印后的结果就是我们想要的:Select * From dbo.Categories where CategoryID=2
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 管理文书 > 工作总结


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!