- 1、本文档共14页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
SQL Server 2008 的 Transact-SQL 语言增强
作者:张洪举 Microsoft MVP
应用于:SQL Server 2008
日期:2008/9/1
Microsoft SQL Server 2008 对 Transact-SQL 语言进行了进一步增强,主要包括:ALTER DATABASE 兼容级别设置、复合运算符、CONVERT 函数、日期和时间功能、GROUPING SETS、MERGE 语句、SQL 依赖关系报告、表值参数和 Transact-SQL 行构造函数。
1.ALTER DATABASE 兼容级别设置
某些数据库行为与 SQL Server 版本有关,通过 ALTER DATABASE 下面新增的语法,可以设置数据库兼容级别,它取代了以前版本中的 sp_dbcmptlevel 过程。
ALTER DATABASE database_name
SET COMPATIBILITY_LEVEL = { 80 | 90 | 100 }
可用的设置值80、90、100分别代表 SQL Server 2000、2005和2008。
2.复合运算符
SQL Server 2008 现在支持如下复合运算符,可执行操作并将变量设置为结果。
运算符
操作
+=
将原始值加上一定的量,并将原始值设置为结果
-=
将原始值减去一定的量,并将原始值设置为结果
*=
将原始值乘上一定的量,并将原始值设置为结果
/=
将原始值除以一定的量,并将原始值设置为结果
%=
将原始值除以一定的量,并将原始值设置为余数
=
对原始值执行位与运算,并将原始值设置为结果
^=
对原始值执行位异或运算,并将原始值设置为结果
|=
对原始值执行位或运算,并将原始值设置为结果
如:
DECLARE @x1 int = 27;
SET @x1 += 2 ;
SELECT @x1 -- 返回29
3.CONVERT 函数
CONVERT 函数现在允许在二进制和字符十六进制值之间进行转换。函数语法格式如下:
CONVERT ( data_type [ ( length ) ] , expression [ , style ] )
expression 是被转换的有效的表达式,data_type 目标数据类型(不能使用别名数据类型),length 指定目标数据类型长度的可选整数,style 指定 CONVERT 函数如何转换 expression 的整数表达式。
如果 expression 为 binary(n)、varbinary(n)、char(n) 或 varchar(n),则 style 可以为下表中显示的值之一。
值
输出
0(默认值)
将 ASCII 字符转换为二进制字节,或者将二进制字节转换为 ASCII 字符。每个字符或字节按照 1:1 进行转换。
如果 data_type 为二进制类型,则会在结果左侧添加字符 0x。
1, 2
对于 style 1,将在转换后的结果左侧添加字符 0x。作为要转换的二进制表达式,字符 0x 必须为表达式中的前两个字符。
在style为2的情况下,生成的二进制值不会包含字符 0x。作为要转换的二进制表达式,也不需要在字符前面包含字符 0x。
如果 data_type 为二进制类型,则表达式必须为字符表达式。
如果转换后的表达式长度大于 data_type 长度,则会在右侧截断结果。
如果固定长度 data_types 大于转换后的结果,则会在结果右侧添加零。
如果 data_type 为字符类型,则表达式必须为二进制表达式。每个二进制字符均转换为两个十六进制字符。如果转换后的表达式长度大于 data_type 长度,则会在右侧截断结果。
如果 data_type 为固定大小的字符类型,并且转换后的结果长度小于其 data_type 长度,则会在转换后的表达式右侧添加空格,以使十六进制数字的个数保持为偶数。
参考下面的示例代码:
--转换二进制值 0x4E616d65 到一个字符值
SELECT CONVERT(char(8), 0x4E616d65, 0) AS Style 0, 二进制到字符
--下面的示例演示了 Style 为 1 的情况下,如何强行截断结果值。
--产生的结果值由于包含字符 0x ,所以被截断
SELECT CONVERT(char(8), 0x4E616d65, 1) AS Style 1, 二进制到字符
--下面的示例演示了 S
您可能关注的文档
最近下载
- 非ST段抬高型急性冠脉综合征诊断和治疗指南(2024)解读.pptx
- 造价咨询采购项目审计服务方案造价咨询方案审计工作要求及时限审计工作安排和保障措施对项目审计的总体分析.docx VIP
- 矿山井巷工程施工及验收规范GBJ213-90.doc
- 浙江省宁波市九校2024-2025学年高一上学期数学期末联考试卷.docx
- 林木委托管护合同.doc VIP
- XHJ-SCB-QR-026开机换线检查表.xls VIP
- 幼儿园书法练字启蒙第二讲完整课件.pptx VIP
- (完整版)千字文带拼音直接打印版.pdf
- 2025年广州中考英语二轮复习语法专项复习课件:专项整合复习一+名词篇.pptx VIP
- 宾馆食品安全知识培训.pptx
文档评论(0)