• 设为首页
  • 收藏本站
  • 积分充值
  • VIP赞助
  • 手机版
  • 微博
  • 微信
    微信公众号 添加方式:
    1:搜索微信号(888888
    2:扫描左侧二维码
  • 快捷导航
    福建二哥 门户 查看主题

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

    发布者: 琛瑞 | 发布时间: 2025-6-18 14:16| 查看数: 39| 评论数: 0|帖子模式

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

    来源:https://www.jb51.net/article/84774.htm
    免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有账号?立即注册

    ×

    最新评论

    QQ Archiver 手机版 小黑屋 福建二哥 ( 闽ICP备2022004717号|闽公网安备35052402000345号 )

    Powered by Discuz! X3.5 © 2001-2023

    快速回复 返回顶部 返回列表