zoukankan      html  css  js  c++  java
  • [小问题笔记(十一)] SQL SERVER 将可空字段改为 NOT NULL不可为空的两个方法

    一个字段里面有一些数据是NULL是很讨厌的,写查询麻烦不说,最重要的is null  或者is not null都是不能命中索引的,会导致全表扫描啊。

    所以对于一个已经存在NULL的字段,有时间的话最好改造改造。

    方法1、为字段添加默认值约束,更新现有NULL值。 此方法简单粗暴,容易引起锁,线上数据慎用。

    -- 1、为现有字段添加默认值约束
    alter table Employee ADD CONSTRAINT DF_Employee_CityID  default (0) for CityID
    
    -- 2、更新现有NULL值
    update Employee set CityID=0 where CityID is null

    方法2、建一个临时表,导入数据,然后修改临时表表名。 

    -- 1、建立一个字段不可为空的临时表
    CREATE
    TABLE Tmp_Employee ( ID int NOT NULL,  CityID int NOT NULL ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

    -- 2、导入现有数据 IF EXISTS(SELECT * FROM Employee) EXEC('INSERT INTO Tmp_Employee (ID, CityID) SELECT ID, CityID FROM dbo.Employee WITH (HOLDLOCK TABLOCKX)')
    -- 3、删除原表
    DROP
    TABLE dbo.Address GO
    -- 4、将临时表重命名 EXECUTE sp_rename N'Tmp_Employee', N'Employee', 'OBJECT' GO

    总结:种种教训告诉我们,建表时候就应该都建成 NOT NULL !!!

    BUT,万事无绝对,比如使用SqlBulkCopy(C#)等批量导表方法时,如果源表数据包含空值,而目标表的字段是NOT NULL,即使删除约束也不行,会报错。特别注意。

  • 相关阅读:
    P3704 [SDOI2017]数字表格
    CF 700 E. Cool Slogans
    杜教筛学习笔记
    [BOI2004]Sequence 数字序列(左偏树)
    [WC2007]剪刀石头布(最大流)
    [NOI2009]变换序列(二分图匹配)
    文理分科(最小割)
    上帝与集合的正确用法(欧拉定理)
    [HAOI2008]圆上的整点(数论)
    主席树学习笔记
  • 原文地址:https://www.cnblogs.com/hydor/p/4349633.html
Copyright © 2011-2022 走看看