当前位置:  开发笔记 > 编程语言 > 正文

为什么SQL表列名中不允许使用特殊字符?

如何解决《为什么SQL表列名中不允许使用特殊字符?》经验,为你挑选了1个好方法。

我创建了一个表并命名其中一个列,因为50"SQL接受了它,但是当我右键单击该表然后单击"编辑前200行"时,SQL Management工作室卡住并停止工作并关闭.

但是,我仍然可以编辑其列名中没有特殊字符的其他表.这听起来像是"列名中不允许的?知道我怎么能包含"列名?



1> Gordon Linof..:

您可以使用转义字符包含几乎任何您可能想要的字符.因此,您可以拥有一个名为的列50".然后你会把它作为参考[50"].你需要躲避名特殊字符(基本上,非字母数字或_)或保留字(如from,select等).

也就是说,您不希望在数据库中包含此类名称.使用方括号(在SQL Server中,其他数据库具有不同的转义机制)只会使查询混乱,使得它们更难以编写和读取.

为什么SQL有这样的限制?嗯,事实上,它是一种计算机语言,所有计算机语言(我认为)都有这样的局限性.例如,在我能想到的任何语言的变量名中都不允许使用未转义的空格(注释中会注明一些例外情况;).

语言本身由语法定义(通常非常接近SQL语法的ANSI标准).语法定义了语言的元素以及它们的开始和结束位置.例如,如果名称中允许使用连字符,则a-b可能是- [a-b]或者[a] - [b]- 解析器无法解析的歧义.

SQL可以很容易地在名称中允许更多的字符(例如,我不认为~?会引起任何混淆),但实际上没有必要.如果你真的想要它们,你总能逃脱它们.

推荐阅读
郑谊099_448
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有