• SqlServer修改某个字段的默认值时的操作步骤


    sqlserver有时候需要修改一个字段的默认值,却发现修改(update)不了,也删除(delete)不了,排查发现,需要先删除原有的默认值约束,才行;步骤如下1、2、3。
    若原来这个字段就没有默认值,则直接执行步骤3的sql;注意,需要显示声明默认值约束,否则系统会默认生成后缀为随机字符串的约束;不利于维护和无法做到见名知意

    1,删除原有字段上的默认值约束
    use [yourDBName];--数据库名
    declare @tableName nvarchar(100);--表名
    declare @columnName nvarchar(100);--列名
    declare @cnt nvarchar(100);
    declare @sqlcmd nvarchar(1024);
    set @tableName='yourTableName'
    set @columnName='yourColumnName'
    select @cnt= b.name from sysobjects b join syscolumns a on b.id = a.cdefault where a.id = object_id(@tableName) and a.name = @columnName
    set @sqlcmd = 'ALTER TABLE '+ @tableName +' DROP constraint ' + @cnt;
    exec sp_executesql @sqlcmd

    2,删除该字段

    ALTER TABLE [schema].[yourTableName] DROP column yourColumnName

    3,重新添加字段

    ALTER TABLE [dbo].[yourTableName] ADD yourColumnName int NOT NULL
    CONSTRAINT DF_yourTableName_yourColumnName  DEFAULT ((-1));
    EXEC sp_addextendedproperty N'MS_Description', N'字段注释', N'SCHEMA', N'dbo',N'TABLE', N'yourTableName', N'COLUMN', N'yourColumnName ';

    4,关于sqlserver约束,这篇文章总结的不错
    https://www.cnblogs.com/wy123/p/9205079.html#4431990

    5,扩展:为什么要设置数据库字段 default  xxx  not null  ?

    1,mysql存储null需要占用space来标识这个字段是不是存的null;如果default 空 那就完美了,因为空不占用space!

    2,sqlserver:如果一个表字段中含有NULL的数据(NULL表示可以为任何值),那么,SQL Server在做数据库比较操作的时候,会使用三值逻辑(TRUE,FALSE,UNKNOWN),而不是平时的二值逻辑(TRUE,FALSE)。因此,在做数据库设计的时候,我们都要求尽量将表不要设置为NULL类型,如果业务要求需要有空值,我们尽量用实际的默认值来代替NULL(int我们用0,字符串可以是空串等),这样SQL Server在做比较运算就不会使用到相对复杂的三值逻辑,而采用二值逻辑。

  • 相关阅读:
    文件字符输入输出流
    ava.io.InputStream & java.io.FileInputStream
    java.io.OutputStream & java.io.FileOutputStream
    java.lang.String & java.lang.StringBuilder
    文件过滤器
    递归
    原生camera应用 保存设置界面参数方法
    android 获取调用camera service的进程
    linux 查找,替换 常用命令
    将一个项目修改记录提交另外一个项目-> patch获取提交记录,repo 提交代码
  • 原文地址:https://www.cnblogs.com/hbuuid/p/11911759.html
Copyright © 2020-2023  润新知