SQL SERVER的QUOTENAME函数

SQL SERVER的QUOTENAME函数quotename使函数中的输入成为一个有效的标识符selectQUOTENAME(‘dddd’) 返回[dddd]selectQUOTENAME(‘dddd’,'”‘)返回”dddd”首先,sqlserver里的标识符有一定的规则,比如 你 createtableabc123(…) 那么中间含有空格,它不是符合规则的。 

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

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺
quotename 使函数中的输入成为一个有效的标识符

select QUOTENAME(‘dddd’)  返回[dddd]

select QUOTENAME(‘dddd’,'”‘) 返回”dddd”

首先,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 

SQL SERVER的QUOTENAME函数

 

–结论

/*

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

*/

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

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/164277.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月25日 上午8:00
下一篇 2022年7月25日 上午8:00


相关推荐

  • 判断数组中是否包含某个元素,判断对象中是否包含某个属性,判断字符串中是否包含某个字符串片段[通俗易懂]

    判断数组中是否包含某个元素,判断对象中是否包含某个属性,判断字符串中是否包含某个字符串片段[通俗易懂]1-判断对象中是否包含某个元素方法一:使用invarstr={name:”mayouchen”,name:”js”,age:100}alert(‘name’instr);//tr

    2022年8月31日
    7
  • SpringMVC实现原理及详解

    SpringMVC实现原理及详解asdfasf

    2022年5月14日
    34
  • 软件设计说明书模版(申请软件著作权可供参考)

    软件设计说明书模版(申请软件著作权可供参考)1 引言 1 1 编写目的 1 2 项目背景 1 2 项目概要总体要求 2 1 系统功能概述 2 2 系统功能要求软件开发 3 1 软件需求分析 3 2 软件的概要设计 3 2 1 软件概要设计说明 3 2 3 基本设计概念和处理流程 3 3 软件的详细设计 3 3 1 系统结构 3 3 2 模块设计说明 3 3 3 爬虫模块 3 3 4 日志模块 3 3 5 数

    2026年3月17日
    2
  • Nutch使用总结

    Nutch使用总结Nutch 使用总结 Nutch 是一个开源 Java 实现的搜索引擎 它提供了我们运行自己的搜索引擎所需的全部工具 包括全文搜索和 Web 爬虫 Nutch 使用方法简介 http blog csdn net pengpengfly archive 2008 09 29 aspxnutch1 2eclipsetomc 0 配置 http hi b

    2026年3月19日
    2
  • OpenGrok在线代码浏览环境搭建

    OpenGrok在线代码浏览环境搭建OpenGrok是专门的源码阅读工具在针对特大型源码时,比如AOSP和Chromium,就需要祭出专门的源码阅读工具。OpenGrok属于另一类,免费,开源,运行流畅,功能也毫不逊色,该工具环境搭建和使用感觉很简单,但最近搭建的过程中遇到各种问题,直到怀疑人生,经历各种磨难最后终于可以到流程使用的程度,特此记录一方面为自己备忘,另一方面希望可以给需要搭建环境的人一些帮助,快速完成,避免重…

    2022年6月6日
    67
  • java 时序图

    java 时序图UML 时序图 又叫序列图或者顺序图 是一种用来描述对象之间传送消息的时间顺序 是用来表示用例中的行为顺序 UML 时序图最基本的符号即含义 1 对象 表示系统的参与者或者任何有效的系统对象 2 生命线 相当于一个时间线 表示对象在一段时间内的存在时间 而且从时序图的顶部一直延伸至底部 长度取决于交互的时间 3 消息 是用来表示一个对象向其他一个或者多个对象发送信号 或者由

    2025年10月12日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

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