当前位置:首页 » 编程语言 » sql约束名查询
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

sql约束名查询

发布时间: 2022-02-04 20:51:10

1. sql中用语句查看表列的约束以及解除约束

SELECT
USER_CONS_COLUMNS.CONSTRAINT_NAMEAS约束名,
USER_CONS_COLUMNS.TABLE_NAMEAS表名,
USER_CONS_COLUMNS.COLUMN_NAMEAS列名,
USER_CONS_COLUMNS.POSITIONAS位置,
CONSTRAINT_TYPE,
SEARCH_CONDITION
FROM
USER_CONSTRAINTS
JOINUSER_CONS_COLUMNS
ON(USER_CONSTRAINTS.CONSTRAINT_NAME
=USER_CONS_COLUMNS.CONSTRAINT_NAME)
WHERE
CONSTRAINT_TYPEIN('C','V','O');

其实主要就是看

USER_CONSTRAINTS与 USER_CONS_COLUMNS 这2个视图.

数据库管理员的话

可以看

DBA_CONSTRAINTS与 DBA_CONS_COLUMNS 这2个视图.

2. 如何知道SQL中默认值约束名称是什么

如果作者没有指定DEFAULT约束名,那么系统会自动命名,可以用以下语句获得该DEFAULT约束名:
select name from sys.default_constraints
where parent_object_id=object_id('表名')
and parent_column_id=columnproperty(object_id('表名'),'列名',columnid)

3. 如何写SQL查询一个约束条件的内容

sp_helptext约束名

可以查看系统相关的系统存储过程,可以查看表约束存储过程函数的内容sp_help相关存储过程用法

这样可以吗? 如有疑问,及时沟通!

请采纳!

4. sqlserver数据库里怎么查找一个表里的约束,要查出 约束名、列名、约束类型用sql语句查询

上面的各楼对SQLSERVER的系统对象操作的语句,要切换到master数据库中。
切记切记。

5. SQL在建立约束时,给约束取得名字是干什么用怎么用约束名字存在哪里了

给约束取名字, 目的是将来你可以比较容易的删除掉.

否则你要自己去查询数据字典表.


例如下面的例子.

唯一约束的名字, 是 t_123, 那么当我不需要这个约束的时候

如果我知道名字, 那么可以直接去删除掉.




--创建测试表.
CREATETABLEtest_123(
idINT,
valueVARCHAR(10)
);
GO

--创建UNIQUE约束.
ALTERTABLEtest_123
ADDCONSTRAINTt_123UNIQUE(value);
GO

--删除UNIQUE约束.
ALTERTABLE[test_123]
DROPCONSTRAINT[t_123];
GO


如果我不知道约束的名字, 那么我需要去查询数据字典表


SELECT
tab.nameAS[表名],
idx.nameAS[约束名称],
col.nameAS[约束列名]
FROM
sys.indexesidx
JOINsys.index_columnsidxCol
ON(idx.object_id=idxCol.object_id
ANDidx.index_id=idxCol.index_id
ANDidx.is_unique_constraint=1)
JOINsys.tablestab
ON(idx.object_id=tab.object_id)
JOINsys.columnscol
ON(idx.object_id=col.object_id
ANDidxCol.column_id=col.column_id);


查询到约束名称以后, 在删除掉这个约束.



以上 SQL 语句, SQL Server 2008 Express 下测试通过。

其他数据库, 由于 数据字典表不同, 因此语句也就不同了。

6. sql语句,怎么查看一个表中的所有约束

sp_mshelpcolumns student
如上可以看到该表的所有结构、约束、默认值等

7. 在SQL sever数据库中用查询分析器用怎么修改约束名

使用sp_rename:

exec sp_rename '旧约束名','新约束名','OBJECT'

8. ORACLE sqlplus查看某个表的指定列的约束名,使用什么命令

据我所知,sqlplus的命令中,没有直接查询约束的。
column column_name;可以查询相关column的属性,这个属性包括约束,但是不包括约束名称(比如外键名称等)。
所以要查询约束名称还是需要通过sql语句,查询相关视图获得。
语句为:
select CONSTRAINT_NAME from user_cons_columns where table_name='XXXXX' and COLUMN_NAME='XXXXXX';(注意:XXXXX均为大写)

9. sql查询表中的约束

exec sp_helpconstraint S

ALTER TABLE S DROP CONSTRAINT 你自己的约束名称;

10. 如何在sqlserver查询中与一个表约束的其它表名

主键约束
SELECT
tab.name AS [表名],
idx.name AS [主键名称],
col.name AS [主键列名]
FROM
sys.indexes idx
JOIN sys.index_columns idxCol
ON (idx.object_id = idxCol.object_id
AND idx.index_id = idxCol.index_id
AND idx.is_primary_key = 1)
JOIN sys.tables tab
ON (idx.object_id = tab.object_id)
JOIN sys.columns col
ON (idx.object_id = col.object_id
AND idxCol.column_id = col.column_id);

唯一约束
SELECT
tab.name AS [表名],
idx.name AS [约束名称],
col.name AS [约束列名]
FROM
sys.indexes idx
JOIN sys.index_columns idxCol
ON (idx.object_id = idxCol.object_id
AND idx.index_id = idxCol.index_id
AND idx.is_unique_constraint = 1)
JOIN sys.tables tab
ON (idx.object_id = tab.object_id)
JOIN sys.columns col
ON (idx.object_id = col.object_id
AND idxCol.column_id = col.column_id);

外键约束
select
oSub.name AS [子表名称],
fk.name AS [外键名称],
SubCol.name AS [子表列名],
oMain.name AS [主表名称],
MainCol.name AS [主表列名]
from
sys.foreign_keys fk
JOIN sys.all_objects oSub
ON (fk.parent_object_id = oSub.object_id)
JOIN sys.all_objects oMain
ON (fk.referenced_object_id = oMain.object_id)
JOIN sys.foreign_key_columns fkCols
ON (fk.object_id = fkCols.constraint_object_id)
JOIN sys.columns SubCol
ON (oSub.object_id = SubCol.object_id
AND fkCols.parent_column_id = SubCol.column_id)
JOIN sys.columns MainCol
ON (oMain.object_id = MainCol.object_id
AND fkCols.referenced_column_id = MainCol.column_id)

Check约束
SELECT
tab.name AS [表名],
chk.name AS [Check约束名],
col.name AS [列名],
chk.definition
FROM
sys.check_constraints chk
JOIN sys.tables tab
ON (chk.parent_object_id = tab.object_id)
JOIN sys.columns col
ON (chk.parent_object_id = col.object_id
AND chk.parent_column_id = col.column_id)