一个字段里面有一些数据是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 !!!