码迷,mamicode.com
首页 > 其他好文 > 详细

关于计算列

时间:2016-04-06 18:55:57      阅读:163      评论:0      收藏:0      [点我收藏+]

标签:t-sql编程

看到网上有人使用“计算列”(computed coulumn)来强制开发人员禁止SELECT * FROM XXX这种语句的使用。以下是一个简单的例子:

--建表
IF OBJECT_ID(N‘T35‘) IS NOT NULL
BEGIN
    DROP TABLE T35;
END;
GO
CREATE TABLE T35
(
    col_1 INT,
    col_2 AS ( 1 / 0)
)
GO
--插入数据
INSERT INTO dbo.T35(col_1) VALUES(168);
GO

Code-1: 创建测试表并插入数据




--查询SELECT * FROM dbo.T35;GO

Code-2: 查询



使用SELECT * FROM XXX语句查询,会报错:

“Msg 8134, Level 16, State 1, Line 3

Divide by zero error encountered.”


技术分享

Figure-1: 运行时报错



而指定字段,则正常运行。

技术分享

Figure-2: 指明字段,运行正常



这种方法的确是可以实现“禁止使用*”的功能,但我个人觉得并不太建议这样做。首先,这本来就是要求开发人员自己主动避免使用*代替所有字段的这个坏习惯,而不应该要求数据库强制报错来避免。第二,如果表的字段很多,在测试或DEBUG时,造成不方便。第三,如果已经运行的系统,还要修改表结构甚至程序,不值得。第四,看到(1/0)这样的逻辑错误,即使最后不会执行,也应该尽量避免吧?如果,万一,我说的是万一……请看下估计执行计划:

技术分享

Figure-3: Estimated Excution Plan




修改一下计算列,去查看估计执行计划。

--建表
IF OBJECT_ID(N‘T35‘) IS NOT NULL
BEGIN
    DROP TABLE T35;
END;
GO
CREATE TABLE T35
(
    col_1 INT,
    col_2 AS ( col_1 / 0) --修改了这里
)
GO
--插入数据
INSERT INTO dbo.T35(col_1) VALUES(168);
GO

Code-3: 修改表




技术分享

Figure-4: Estimated Excution Plan 2

都没有报错。为什么呢??




本文出自 “FishParadise” 博客,请务必保留此出处http://fishparadise.blog.51cto.com/11284420/1760988

关于计算列

标签:t-sql编程

原文地址:http://fishparadise.blog.51cto.com/11284420/1760988

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!