zoukankan      html  css  js  c++  java
  • SQL Server ->> 生成代码把表字段从NULL改为NOT NULL

    一般我们用SELECT .... INTO语句生成的表字段都是允许为NULL。而如果我们需要改成NOT NULL呢

    select 'ALTER TABLE dbo.XXXXXXX ALTER COLUMN ' + 
    QUOTENAME(c.name) + ' ' + t.name + 
    case when t.name in ('nvarchar','nchar') 
            then '('+ cast(c.max_length/2 as nvarchar) +')' 
        when t.name in ('varchar','binary', 'char', 'varbinary') 
            then '('+ cast(c.max_length as nvarchar) +')' 
    else '' end + ' NOT NULL'
    from sys.columns c join sys.types t on c.system_type_id = t.system_type_id 
    where object_id = object_id ('dbo.XXXXXXX') and t.name <> 'sysname'
    order by column_id 

    有时需要准备数据库设计文档,里面的物理设计这块需要填写像这样的表

    Table: dbo.DimMonth

    Column Name

    Data Type

    Key

    Nullable

    Comment

    Monthkey

    bigint

    PK

    No

     

    CalendarMonth

    bigint

     

    No

     

    CalendarMonthName

    nvarchar(30)

     

    No

     

    CalendarQuarter

    bigint

     

    No

     

    CalendarQuarterName

    nvarchar(30)

     

    No

     

    CalendarYear

    bigint

     

    No

     

    CalendarYearName

    nvarchar(30)

     

    No

     

    FiscalMonthName

    nvarchar(30)

     

    No

     

    FiscalMonthOfYear

    bigint

     

    No

     

    FiscalQuarter

    bigint

     

    No

     

    FiscalQuarterName

    nvarchar(30)

     

    No

     

    FiscalYear

    bigint

     

    No

     

    FiscalYearName

    nvarchar(30)

     

    No

     

    如果比本身已经建立好在数据库中,我们可以通过一条脚本生成

    select c.name, t.name + case when t.name in ('nvarchar','nchar') 
            then '('+ cast(c.max_length/2 as nvarchar) +')' 
        when t.name in ('varchar','binary', 'char', 'varbinary') 
            then '('+ cast(c.max_length as nvarchar) +')' 
    else '' end, case when c.is_nullable = 1 then 'Yes' ELSE 'No' end
    from sys.columns c join sys.types t on c.system_type_id = t.system_type_id 
    where object_id = object_id ('dbo.XXXXXXX') and t.name <> 'sysname'
    order by column_id 
  • 相关阅读:
    队列

    Oracle 12c新特性之——TABLE ACCESS BY INDEX ROWID BATCHED
    连续三月涨势明显,PostgreSQL 将崛起?
    Oracle物理DG自动切换——Dataguard Broker配置
    MSSQL索引视图(indexed view)之简述及使用
    连续三月涨势明显,PostgreSQL 将崛起?
    Scheduler & Task & Worker & Thread & Request & Session & Connection of SQL Server
    MSSQL内存架构及管理
    MSSQL数据库后台进程(线程)
  • 原文地址:https://www.cnblogs.com/jenrrychen/p/4894812.html
Copyright © 2011-2022 走看看