当前位置:  开发笔记 > 数据库 > 正文

我应该始终在SQL中完全限定列名吗?

如何解决《我应该始终在SQL中完全限定列名吗?》经验,为你挑选了2个好方法。

在使用SQL语句时,我应该始终使用完全限定的列名(tablename.columnname),即使只使用一个表,例如

SELECT table.column1, table.column2 FROM table

Adam Davis.. 11

如果你这样做会更好 - 它不会增加任何复杂性,它可以防止将来出现错误.

但是,在一个良好定义的系统,你不应该 -它就像在编程语言的命名空间.理想的情况不是存在冲突,但它可能会使用显式名称多余地使代码混乱.

-亚当



1> Adam Davis..:

如果你这样做会更好 - 它不会增加任何复杂性,它可以防止将来出现错误.

但是,在一个良好定义的系统,你不应该 -它就像在编程语言的命名空间.理想的情况不是存在冲突,但它可能会使用显式名称多余地使代码混乱.

-亚当



2> jonstjohn..:

我通常遵循以下规则:

使用单个表时,不必使用表名前缀:

SELECT col1, col2 FROM table1

对于多个表,请使用完整的表名.别名可能会造成混淆,尤其是在进行多个连接时:

SELECT table1.col1, table2.col2 FROM table1 INNER JOIN table2 on 
            table1.id = table2.id

我看到许多开发人员使用表别名,但特别是在有多个开发人员的大型项目中,这些可能会变得神秘.一些额外的击键可以提高代码的清晰度.

但是,如果列具有相同的名称,则可能需要使用列别名.在这种情况下:

    SELECT table1.col1, table2.col1 as table2_col1 FROM table1 
            INNER JOIN table2 on 
            table1.id = table2.id

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