SQL2005关于quotename的用法(转)[通俗易懂]

SQL2005关于quotename的用法(转)[通俗易懂]首先,sqlserver里的标识符有一定的规则,比如 你createtableabc123(…)那么中间含有空格,它不是符合规则的。你会写做createtable[abc123](….)即以[]来定界标识符。quotename将字串成为有效的标识符。它有什么用呢?我举个例子:你有个表名字叫做aa[]bb当

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

首先,sqlserver里的标识符有一定的规则,比如  你
create table abc 123(…)
那么中间含有空格,它不是符合规则的。

你会写做 create table [abc 123](….)
即以[]来定界标识符。

quotename将 字串成为有效的标识符。

它有什么用呢? 我举个例子:

你有个表名字叫做 aa[]bb

当某些应用动态语句查询时 你如何写呢
exec(‘select * from aa[]bb’) ?X

set @sql=’select * from ‘ + quotename(‘aa[]bb’)
exec(@sql)

当然你也可以直接写出转义的写法

select * from [aa[]]bb]

也就是说,quotename 使函数中的输入成为一个有效的标识符。
比如上例中 aa[]bb 不是一个有效的标识符。

还有一点就是quotename函数有几种写法:
  quotename(‘aa’) 生成的有效的标识符为 [aa]
  quotename(‘aa’,”) 生成的有效的标识符为 [aa]
  quotename(‘aa’,””) 生成的有效的标识符为 ‘aa’

 

解释2:

简单来说吧
比如你有一个表,名字叫 index
你有一个动态查询,参数是表名
declare @tbname varchar(256)
set @tbname=index
-查这个表里的数据:
print(select * from +@tbname)
exec(select * from +@tbname)

这样print出来的数据是
select * from index

因为index是字键字,肯定出错,加上括号就可以了:
select * from [index]

这便有了QUOTENAME,即:
print(select * from +QUOTENAME(@tbname))
结果:select * from [index]
exec(select * from +QUOTENAME(@tbname))

 

 

返回带有分隔符的 Unicode 字符串,分隔符的加入可使输入的字符串成为有效的 Microsoft SQL Server 2005 分隔标识符。

 

Transact-SQL 语法约定

 

语法

 
QUOTENAME ( 'character_string' [ , 'quote_character' ] ) 

参数

‘character_string’

Unicode 字符数据构成的字符串。character_string 是 sysname 值。

‘quote_character’

用作分隔符的单字符字符串。可以是单引号 (‘)、左方括号或右方括号 ([ ]) 或者英文双引号 (“)。如果未指定 quote_character,则使用方括号。

返回类型

nvarchar(258)

示例

以下示例接受字符串 abc[]def 并使用 [] 字符来创建有效的 SQL Server 分隔标识符。

 
SELECT QUOTENAME('abc[]def')

 

下面是结果集: 

 
[abc[]]def]

(1 row(s) affected)

 

请注意,字符串 abc[]def 中的右方括号有两个,用于指示转义符。

为什么输出结果是:[abc[]]def]呢?

[abc[]]def]
分解成
[]]中间的]是表示右边的]是原样输出也就是说]]就表示]
就跟”中的’要用”来表示一样

就是说和]]转义后得到–> ] 和两个单引号转义成一个单引号是一个道理

 

quotename函数看分隔符是什么因为默认是[ ] ,如果用的是}作分界符,那么 SELECT QUOTENAME(‘abc[]def’)

就不会发生转义了.

select QUOTENAME(abcdef,””) –分隔符是两个单引号
‘abc”def’
select QUOTENAME(abc]def) –分隔符是]
[abc]]def]
select QUOTENAME(abc}def,{}) –分隔符是}
{abc}}def}

示例:

create table tab([i[]]d] int);
go
select name from sys.columns where object_id=object_id(tab);
/* i[]d */

也就是说:SELECT QUOTENAME(‘abc[]def’) ,quotename函数默认分隔符是[ ]
所以在给quotename(‘abc[]def’)需要对abc后的[]进行转义,如果quotename(‘abc[]def’,'{‘)
也就是设置了分隔符为{就不会发生转义,该转义取决于分隔符.

 

简单的说假设你要在分隔符在[ ]里面使用[]那么就必须对综括号里面的]进行转义:]]
所以结果为:[abc[]]def],同理要在{}里面使用{}那么必须对}进行转义:}}
那么结果为:{abc{}}def}

示例:

select quotename(abc[]def) –默认是分隔符:[ ]
–[abc[]]def]
select quotename(abc{}def,})
–{abc{}}def}

 

 

QUOTENAME()函数 

 

   这个函数和SQL Server对象名组合使用,以将结果传递给表达式。它只用于给输入的字符串加一对方括号,并返回新形成的字符串。如果参数包含保留的分隔符或者封装字符(比如引号或括号),这个函数将修改字符串,以便SQL Server能将结果字符串中的这类字符当成文本字符。如下面的例子所示,查询的结果如图

 

  1. SELECT QUOTENAME(COLUMN_NAME) AS ColumnName  
  2. FROM INFORMATION_SCHEMA. COLUMNS 

SQL2005关于quotename的用法(转)[通俗易懂]

 

–结论

/*

初步理解为解决有些对象是SQLSERVER关键字的情况,即用该函数规范对象名,以便程序顺利运行

*/

http://www.cnblogs.com/Fskjb/archive/2010/04/19/1715105.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/164266.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 去除a标签的下划线

    去除a标签的下划线很久没写忘记的差不多了,写下这个方便以后查看,好了话不多说,消除A标签的这么实现呢使用”text-decoration:none;”属性即可:1,一开始是这个样的,是不是有下划线2,下面是我添加了样式的<astyle=”text-decoration:none;”>我们没有下划线</a>结果如下,这样就没有下划线了…

  • Java高级工程师面试题总结及参考答案「建议收藏」

    Java高级工程师面试题总结及参考答案「建议收藏」一、面试题基础总结1、JVM结构原理、GC工作机制详解答:具体参照:JVM结构、GC工作机制详解,说到GC,记住两点:1、GC是负责回收所有无任何引用对象的内存空间。注意:垃圾回收回收的是无任何引用的对象占据的内存空间而不是对象本身,2、GC回收机制的两种算法,a、引用计数法b、可达性分析算法(这里的可达性,大家可以看基础2Java对象的什么周期),至于更详细的GC…

  • pycharm怎么安装python_pycharm环境配置教程

    pycharm怎么安装python_pycharm环境配置教程1.pycharm的下载,到pycharm官方网站进行下载点击tools选择自己要下载的pycharm的版本2.下载完成安装以后如图所示:创建一个快捷方式,以便打开3.根据安装的提示一步一步往下走就可以了4.Python下载:4.1到Python官网下载Python我下载的是3.9.6版本的Python4.2安装时记得点击path的那个选项,这样就不用了自己去环境那边配置了4.3安装完成以后,在命令提示行下检查一下是否安装成功…

  • 02-Epicor二次开发常用代码

    02-Epicor二次开发常用代码二次开发,俗称客制。是程序员根据需求,进入开发模式对Epicor进行代码修改。1、获取到的完整的SQL,可以将SQL语句弹出来2、每个公司的代码是一样的,不一样请清理系统缓存,并退出系统重新进入3、隐藏一列4、关于界面居中问题5、测试跟正式的水晶报表文件都在192.168.100.250的EpicorData\CustomReports文件夹中6、关于报表位置不够问题7、将DataView的数据转化为xml的文件,用于更新水晶报表8、vb.net中换行…

  • iPhone6分辨率与适配[通俗易懂]

    (via:sunnyxx’sblog) 分辨率和像素经新xcode6模拟器验证(分辨率为pt,像素为真实pixel):1.iPhone5分辨率320×568,像素640×1136,@2×2.iPhone6分辨率375×667,像素750×1334,@2×3.iPhone6Plus分辨率414×736,像素1242×2208,@3x,(注意,在这个

  • 为什么Redis选择6379作为默认端口号?[通俗易懂]

    为什么Redis选择6379作为默认端口号?[通俗易懂]6379在是手机按键上MERZ对应的号码,而MERZ取自意大利歌女AlessiaMerz的名字。MERZ长期以来被antirez及其朋友当作愚蠢的代名词。Redis作者antirez同学在twitter上说将在下一篇博文中向大家解释为什么他选择6379作为默认端口号。而现在这篇博文出炉,在解释了Redis的LRU机制之后,向大家解释了采用6379作为默认端口的原因。原博文:http://anti…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号