主页 > 知识库 > sql server 关于设置null的一些建议

sql server 关于设置null的一些建议

热门标签:地方门户网站 铁路电话系统 AI电销 百度竞价排名 服务外包 呼叫中心市场需求 Linux服务器 网站排名优化

我们设计表时,在字段是否允许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,并为字段附上默认值

您可能感兴趣的文章:
  • sqlserver2005 安装图解教程以及SQL 2005 SP3补丁安装图文教程
  • MySQL server has gone away 问题的解决方法
  • sqlserver中distinct的用法(不重复的记录)
  • SQL Server 2008 安装和配置图解教程(附官方下载地址)
  • SQL Server 2008 阻止保存要求重新创建表的更改问题的设置方法
  • SQL Server数据库入门学习总结
  • SQL Server 2012 安装图解教程(附sql2012下载地址)
  • Sql Server 2008完全卸载方法(其他版本类似)
  • SQL Server 在Management Studio中使用Web浏览器

标签:黄山 湖南 衡水 兰州 铜川 湘潭 崇左 仙桃

巨人网络通讯声明:本文标题《sql server 关于设置null的一些建议》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266