SQL实现表名更改,列名更改,约束更改

SQL实现表名更改,列名更改,约束更改 (转)

  1. 修改表名

    格式:sp_rename tablename,newtablename

    sp_rename tablename,newtablename
  2. 修改字段名

    格式:sp_rename ‘tablename.colname‘,newcolname,‘column‘

    sp_rename ‘tablename.colname‘,newcolname,‘column‘
  3. 添加字段

    格式:alter table table_name add new_column data_type [interality_codition]

    示例1
    ALTER TABLE student Add nationality varchar(20)
    
    --示例2 添加int类型的列,默认值为 0
    alter table student add studentName int default 0
    
    --示例3 添加int类型的列,默认值为0,主键
    alter table student add studentId int primary key default 0    
    
    --示例4 判断student中是否存在name字段且删除字段
    if exists(select * from syscolumns where id=object_id(‘student‘) and name=‘name‘) begin
    alter table student DROP COLUMN name
    end 
  4. 更改字段

    格式:alter table table_name alter column column_name

    ALTER TABLE student ALTER COLUMN name VARCHAR(200)
  5. 删除字段

    格式:alter table table_name drop column column_name

    ALTER TABLE student DROP COLUMN nationality;
  6. 查看字段约束

    格式: select * from information_schema.constraint_column_usage where TABLE_NAME = table_name

    SELECT TABLE_NAME,COLUMN_NAME,CONSTRAINT_NAME FROM information_schema.CONSTRAINT_COLUMN_USAGE
    WHERE TABLE_NAME = ‘student‘
  7. 查看字段缺省约束表达式 (即默认值等)

    格式:select * from information_schema.columns where TABLE_NAME = table_name

    SELECT TABLE_NAME, COLUMN_NAME, COLUMN_DEFAULT FROM information_schema.COLUMNS
    WHERE TABLE_NAME=‘student‘
  8. 查看字段缺省约束名

    格式:select name from sysobjects where object_id(table_name)=parent_obj and xtype=’D’

    select name from sysobjects
    where object_id(‘表?名?‘)=parent_obj and xtype=‘D‘
  9. 删除字段约束

    格式:alter table tablename drop constraint constraintname

    ALTER TABLE student DROP CONSTRAINT PK__student__2F36BC5B772B9A0B
  10. 添加字段约束

    格式:alter table tablename add constraint constraintname primary key (column_name)

    --示例1
    ALTER TABLE stuInfo ADD CONSTRAINT PK_stuNo PRIMARY KEY (stuNo)
    
    --示例2  添加主键约束(Primary Key)
    -- 存在主键约束PK_stuNO,则删除
    IF EXISTS(SELECT * FROM sysobjects WHERE name=‘PK_stuNo‘ and xtype=‘PK‘)
        Alter TABLE stuInfo
    Drop Constraint PK_stuNo
    Go
    -- 重新添加主键约束PK_stuNO
    ALTER TABLE stuInfo  ADD CONSTRAINT PK_stuNo PRIMARY KEY (stuNo)
    Go
    
    --示例3 添加 唯一UQ约束(Unique Constraint)
    -- 存在唯一约束UQ_stuNO,则删除
    IF EXISTS(SELECT * FROM sysobjects WHERE name=‘UQ_stuID‘ and xtype=‘UQ‘)
        Alter TABLE stuInfo
    Drop Constraint UQ_stuID
    Go
    -- 重新添加唯一约束UQ_stuID
    ALTER TABLE stuInfo ADD CONSTRAINT UQ_stuID UNIQUE (stuID)
    
    --示例4 添加默认DF约束(Default Constraint)
    -- 存在默认约束UQ_stuNO,则删除
    IF EXISTS(SELECT * FROM sysobjects WHERE name=‘DF_stuAddress‘ and xtype=‘D‘)
        Alter TABLE stuInfo Drop Constraint DF_stuAddress
    Go
    -- 重新添加默认约束DF_stuAddress
    ALTER TABLE stuInfo  ADD CONSTRAINT DF_stuAddress DEFAULT (‘地址不详‘) FOR stuAddress
    
    --示例5 检查CK约束(Check Constraint)
    -- 存在检查约束UQ_stuNO,则删除
    IF EXISTS(SELECT * FROM sysobjects WHERE name=‘CK_stuAge‘ and xtype=‘C‘)
        Alter TABLE stuInfo Drop Cons
时间: 2024-11-08 18:58:04

SQL实现表名更改,列名更改,约束更改的相关文章

SQL获取数据库名,表名,列名,说明等信息

由于最近工作涉及SQL语句较多,对一些不常见的SQL函数.及存储过程下面进行整理和描述,供大家分享: /************************************************************************************************************** 1.获取所有用户名: islogin='1' :表示帐户 islogin='0' :表示角色 status='2' :表示用户帐户 status='0' :表示系统帐户 **

PL/SQL Developer_如何快速获得表名或列名的文本形式

原创作品,出自 "深蓝的blog" 博客,欢迎转载,转载时请务必注明以下出处,否则追究版权法律责任. 深蓝的blog:http://blog.csdn.net/huangyanlong/article/details/41513537 实验:使用PL/SQL Developer软件获得表名.列名的文本形式 操作过程: 例1:以"逗号"格式获取"用户表名"的文本 使用scott登陆到PL/SQL Developer,在All objects框处找到

PostgreSQL-JDBC疑似bug:部分接口参数的表名、列名必须全部小写

项目从Oracle移植到PostgreSQL(9.4版)后,这几天又出现故障,经跟踪定位,确定原因是调用PgDatabaseMetaData.getPrimaryKeys()接口返回了空集. 众所周知,大多数情况下SQL语句对表名.列名都是大小写不敏感(据本人经验,linux平台的MySql默认对表名区分大小写,可算是个例外).对应的,各数据库JDBC也理应对大小写不敏感,但实际情况是:PostgreSQL的JDBC的部分接口只认全部小写的表名.列名,而对全大写.大小写混合的情况都不支持. Po

mybatis动态传入表名、列名

原文:http://luoyu-ds.iteye.com/blog/1517607 要实现动态传入表名.列名,需要做如下修改 添加属性statementType="STATEMENT" (可省略) 同时sql里的属有变量取值都改成${xxxx},而不是#{xxx} <delete id="deleteTableData" parameterType="java.util.Map" statementType="STATEMENT&

JPA中自动使用@Table(name = &quot;userTab&quot;)后自动将表名、列名添加了下划线的问题

一.问题 JPA中自动使用@Table(name = "userTab")后自动将表名.列名添加了下划线的问题,如下图: 二.解决 在application.properties文件中加入: spring.jpa.hibernate.naming.physical-strategy=org.hibernate.boot.model.naming.PhysicalNamingStrategyStandardImpl 如: #连接字符串 spring.datasource.driver-c

MySQL表名、列名区分大小写详解

前言:出现的问题 在本地数据库上执行修改银行卡没有报错 但线上执行报错 发现是表找不到,发现表名不对应该是card_cardinfo,但本地上没有问题,能正常修改,然后在数据库里测试,发现本地库(win)下表名不区分大小写,线上(linux)区分 在刚开始使用mysql的时候,刚开始是想要区分列名大小写的问题,在网上看到很多办法,于是就 1. linux下mysql安装完后是默认:区分表名的大小写,不区分列名的大小写:   2. 2.用root帐号登录后,在/etc/my.cnf中的[mysql

Mybatis中如何在SQL语句表名中使用参数

insert into prefix_${table_name} (a, b, c) values (#{a}, #{b}, #{c}) ${} 表示直接使用字面量(literal value) #{} 表示这个是个参数 如果 table_name 是 "ABC" 则 ${table_name} 是 ABC #{table_name} 是 "ABC" Mybatis中如何在SQL语句表名中使用参数,布布扣,bubuko.com

C#获取Access数据库中的所有表名和列名

//C#获取Access数据库中的所有表名和列名    string ConnectionString = "Provider=Microsoft.Jet.OLEDB.4.0;" + @"Data Source=E:\report20100819\report20100819.mdb";    OleDbConnection Conn = new OleDbConnection(ConnectionString);    Conn.Open(); DataTable

mssqlserver修改表名,列名,添加表列,删除表列,修改表列类型

mssqlserver修改表名,列名,添加表列,删除表列,修改表列类型 ,代码肯定省事的呀 --添加表列 alter table test add address nvarchar(50) null; --删除表列 alter table test drop column address; --修改表列字段类型 alter table test alter column address char(10); --修改表列字段名 exec sp_rename '表名.[列名]', '新的列名', '