今天遇到一个问题,想要删掉一个表中的某列的唯一约束,google了一下,搜出来许许多多,找到能用的,记下来总结如下。
命令如下
select constname, tabname, colname, colseq from syscat.keycoluse where TABNAME=‘TableName‘
ALTER TABLE DB2ADMIN.BM_SERVERS DROP UNIQUE <constname>;
第一行查找出列对应的constname,第二行呢就将它从表中删除。
先记录下相关的一些可能用到的命令及表【转载】
目录视图 | 视图列 | 描述 | 查询实例 |
SYSCAT.CHECKS | 为每个表检查约束包含一行记录 | db2 select constname, tabname, text from syscat.checks | |
SYSCAT.COLCHECKS | 为表检查约束所引用的每一列包含一行记录 | db2 select constname, tabname, colname, usage from syscat.colchecks | |
SYSCAT.COLUMNS | NULLS | 指明一列是可为空(Y)还是不可为空(N) | db2 select tabname, colname, nulls from syscat.columns where tabschema = ‘MELNYK‘ and nulls = ‘N‘ |
SYSCAT.CONSTDEP | 为某些其他对象上的约束的每个依赖性包含一行记录 | db2 select constname, tabname, btype, bname from syscat.constdep | |
SYSCAT.INDEXES | 为每个索引包含一行记录 | db2 select tabname, uniquerule, made_unique, system_required from syscat.indexes where tabschema = ‘MELNYK‘ | |
SYSCAT.KEYCOLUSE | 为惟一、主键或外键约束定义的键中所包含的每个列包含一行记录 | db2 select constname, tabname, colname, colseq from syscat.keycoluse | |
SYSCAT.REFERENCES | 为每个参照约束包含一行记录 | db2 select constname, tabname, refkeyname, reftabname, colcount, deleterule, updaterule from syscat.references | |
SYSCAT.TABCONST | 为每个惟一(U)、主键(P)、外键(F)或表检查(K)约束包含一行记录 | db2 select constname, tabname, type from syscat.tabconst | |
SYSCAT.TABLES | PARENTS | 该表的父表数目(该表在其中充当子表的参照约束数目) | db2 "select tabname, parents from syscat.tables where parents > 0" |
SYSCAT.TABLES | CHILDREN | 该表的子表数目(该表在其中充当父表的参照约束数目) | db2 "select tabname, children from syscat.tables where children > 0" |
SYSCAT.TABLES | SELFREFS | 该表的自引用参照约束数目(该表在其中既充当父表又充当子表的参照约束数目) | db2 "select tabname, selfrefs from syscat.tables where selfrefs > 0" |
SYSCAT.TABLES | KEYUNIQUE | 在该表上所定义的惟一约束(除了主键)的数目 | db2 "select tabname, keyunique from syscat.tables where keyunique > 0" |
SYSCAT.TABLES | CHECKCOUNT | 在该表上所定义的检查约束的数目 | db2 "select tabname, checkcount from syscat.tables where checkcount > 0" |
更多请查看 http://www.ibm.com/developerworks/cn/data/library/techarticles/dm-0401melnyk/
DB2 官方文档:http://www-01.ibm.com/support/knowledgecenter/SSEPGG_9.7.0/com.ibm.db2.luw.kc.doc/welcome.html?lang=zh
知其然,知其所以然,那么下面就要讨论下这些都是神马啊?当然也是从以上文档中总结出来滴
DB2有五种约束:
- NOT NULL 约束是这样一种规则,它防止在表的一列或多列中输入空值。
- 唯一约束(也称为唯一键约束)是这样一种规则,它禁止表的一列或多列中出现重复值。唯一键和主键是受支持的唯一约束。例如,可对供应商表中的供应商标识定义唯一约束以确保不会对两个供应商指定同一供应商标识。
- 主键约束是与唯一约束具有相同属性的一列或列的组合。可使用主键和外键约束来定义表之间的关系。
- 外键约束(也称为引用约束或引用完整性约束)是关于一个或多个表中的一列或多列中的值的一种逻辑规则。例如,一组表共享关于公司的供应商的信息。供应商的名称有时可能会更改。可定义一个引用约束,声明表中的供应商的标识必须与供应商信息中的供应商标识相匹配。此约束会阻止可能导致丢失供应商信息的插入、更新或删除操作。
- (表)检查约束(也称为检查约束)对添加至特定表的数据设置限制。例如,表检查约束可确保每当在包含个人信息的表中添加或更新薪水数据时,职员的薪水级别至少为 $20000。
创建 Not null:
CREATE TABLE EMPLOYEES (. . .
EMERGENCY_PHONE CHAR(14) NOT NULL,
. . .
);
修改之:
db2 "alter table tabname ALTER colname drop not null"
db2 "alter table t01 ALTER colname set not null"
创建、删除唯一约束:
db2 "alter table tabname add unique(colname)"
db2 "alter table tabname drop unique CONSTNAME "
创建主键约束:
db2 "alter table staff add primary key (id)"
创建外键约束:
db2 alter table project add foreign key (respemp) references employee on delete cascade
表检查约束:
db2 alter table employee add constraint phoneno_length check (length(rtrim(phoneno)) = 4)