SQL点滴之SETQUOTED_IDENTIFIEROFF语句的作用

编者注:SET QUOTED_IDENTIFIER

成都创新互联公司是少有的成都做网站、成都网站设计、营销型企业网站、成都微信小程序、手机APP,开发、制作、设计、外链、推广优化一站式服务网络公司,于2013年成立,坚持透明化,价格低,无套路经营理念。让网页惊喜每一位访客多年来深受用户好评

使 Microsoft® SQL Server™ 遵从关于引号分隔标识符和文字字符串的 SQL-92 规则。由双引号分隔的标识符可以是Transact-SQL 保留关键字,或者可以包含 Transact-SQL 标识符语法规则通常不允许的字符。

先看下面几个sql语句

 
 
 
  1. SET QUOTED_IDENTIFIER ON
  2. SELECT * FROM "USER"    WHERE a='netasp' 
  3.  
  4. SET QUOTED_IDENTIFIER ON
  5. SELECT * FROM [USER] WHERE a='netasp' 
  6. SET QUOTED_IDENTIFIER OFF
  7. SELECT * FROM [USER]    WHERE a="netasp" 
  8. SET QUOTED_IDENTIFIER OFF
  9. SELECT * FROM [USER]    WHERE a= 'netasp'

当在数据库中新建一个名字是USER的表的时候,常常会带来一些麻烦,因为USER是SQL中的关键字,但是上面的几个语句不会报错。再说一个概念:标示符是SQL中的中括号[]。

当SET QUOTED_IDENTIFIER值为ON时,双引号内的字符被当作是数据库对象。就是说双引号" "和标识符[]效果是一样样的,他们都表示引用的字符是数据库对象。单引号'表示字符串的边界。

当SET QUOTDE_IDENTIFIER OFF时,双引号被解释为字符串的边界,和单引号的作用是类似的。就是说双引号"不能当做标识符使用,但是可以当做字符边界,和单引号'的效果是一样样的。

可以做一个总结:当SET QUOTED_IDENTIFIER ON " "等同于[ ] 表示数据库对象;当SET QUOTED_IDENTIFIER OFF " "等同于' '表示字符串边界;还有这里的双引号" 并不是两个单引号'合起来的,是shift+”打出来的,初学者可能会犯这样的错误。

新闻名称:SQL点滴之SETQUOTED_IDENTIFIEROFF语句的作用
标题URL:http://www.hantingmc.com/qtweb/news39/278489.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联