位置: 编程技术 - 正文
推荐整理分享sql server 关于设置null的一些建议(sql2008设置),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:sql server2016功能选择,设置sql,sqlserver2019功能选择,sqlserver2017功能选择,sql server设置,sql2008设置,sqlserver设置用户权限,怎么设置sql server用户权限,内容如对您有帮助,希望把文章链接给更多的朋友!
我们设计表时,在字段是否允许Null值这个问题上,有时会争论一番。
数据库牛人Kalen Delaney则给了一下建议:
1,永远不要在用户表中允许NULL值2,在用户表定义中包含一个NOT NULL限制3,不要依赖数据库属性来控制NULL值的行为
对于第一点,我们反向说,如果允许NULL,会给我们带来什么影响。
1,SQL 在每条记录中都设置了一个特殊的bitmap来显示哪些允许空值的列上存储的真的是空值。如果是NULL,在访问每一行的时候SQL Server都必须对这个bitmap进行解码。2,允许NULL还增加了应用程序代码的复杂度,总的添加一些特殊的逻辑来处理这个NULL值,这常常会导致bug。
第二点,在包含不允许NULL的列上,要加入一些默认值,如果不允许NULL,但是还没有加默认值,在没有显示列插入的话,就会造成INSERT的失败,SQL Server默认在INSERT中,对没有显示的列做NULL插入。
最后一点,主要涉及到于NULL值的比较。在我们印象中,是用IS NULL,IS NOT NULL比较呢,还是用=,<>比较呢。这取决于数据库选项ANSI NULLS,我们不可能更改数据库选项(我们大部分不是DBA),但是我们可以使用会话设置SET ANSI_NULLS相当于数据库选项ANSI NULLS。当这个选项为真是,所有与空值的比较都将得出FALSE,代码必须使用IS NULL条件来判断是否为空,而当这个选项为假时,如果进行比较的两个值都是空值将得出TRUE,SQL Server允许将 =NULL作为IS NULL的同义词,将<> NULL 作为IS NOT NULL的同义词。
如果忘记这个选项,建议用IS NULL判断空,IS NOT NULL判断非空。
测试如下:
在t3表中只有两行数据,如图:
SET ANSI_NULLS OFF 时:
SET ANSI_NULLS ON 时
总结下来,最优的办法是:在设计表的时候,不要允许字段为NULL,并为字段附上默认值。
SQL Server 在Management Studio中使用Web浏览器 我们在SQLServerManagementStudio中写SQL的时候,避免不了在浏览器和SSMS两者之间频繁切换,并浪费时间,殊不知,SSMS中自带有一个Web浏览器,和操作查询标
SQL Server 使用 SET FMTONLY ON 获得表的元数据 有时,我们需要获得某张表所有的元数据,我们可能想到的是通过查询系统表获得,但是这比较繁琐,而在SQLServer(包含)以后,提供了一个比较简单
把CSV文件导入到SQL Server表中的方法 有时候我们可能会把CSV中的数据导入到某个数据库的表中,比如做报表分析的时候。对于这个问题,我想一点也难不倒程序人员吧!但是要是SQLServer能
标签: sql2008设置
本文链接地址:https://www.jiuchutong.com/biancheng/312196.html 转载请保留说明!友情链接: 武汉网站建设