
sql语句查询数据库中的表名/列名/主键/自动增长值
发布日期:2021-05-09 04:01:45
浏览次数:21
分类:博客文章
本文共 4052 字,大约阅读时间需要 13 分钟。
原文地址:
----查询中用户创建的表----jsj01 为数据库名
select name tablename from jsj01..sysobjects where type='U' and name not in ('dtproperties')
--查询表里的字段信息
exec sp_help 对象名
---docs为表名
select * from syscolumns where id = object_id('docs')
----查询数据库中所有类型
select name,xtype from systypes
----两表联查,显示表中所有字段和对应的数据类型----syscolumns里字段‘xtype’ 对应 systypes里的 ‘xusertype’ ,systypes 里的‘name’字段就是字段的数据类型----docs 为表名
select a.name as fieldname,b.name as type from syscolumns as a join systypes as b on a.xtype = b.xusertype where id=object_id('docs')
----docs为数据表名 : 查询表字段、类型、说明
select a.name fieldname,b.name type,c.value comment from syscolumns as a full join systypes as b on a.xtype = b.xusertypefull join ::fn_listextendedproperty(NULL, 'user', 'dbo', 'table', 'docs', 'column', default) as c ----这是2000版本,2005把user改为schemaon a.name=c.objname COLLATE Chinese_PRC_CI_AS -----排序规则(有时不加也可以,如果两表的排序规则不同,则会报错)--join sysproperties c--on a.id=c.major_idwhere id=object_id('docs')
----查询表里的主键,没有主键为空,如果是多个组合主键就有多个值 pk为主键 fk为外键--- jsj01 为数据库名 docs为表名 fk表示外键
----sql2000
select column_name as primarykey,* from [jsj01].INFORMATION_SCHEMA.KEY_COLUMN_USAGE where Table_name='docs' and constraint_name like 'fk_%'
-----sql2005
SELECT @PrimaryKey = CCU.COLUMN_NAMEFROM INFORMATION_SCHEMA.TABLE_CONSTRAINTS TC INNER JOIN INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE CCU ON TC.CONSTRAINT_NAME = CCU.CONSTRAINT_NAMEWHERE TC.TABLE_NAME = 'docs' AND TC.CONSTRAINT_TYPE='PRIMARY KEY'
--select * from sysobjects WHERE OBJECT_NAME(sysobjects.parent_obj)='docs' --and xtype='pk'--select * from sysconstraints where id = object_id('docs')--select * from syscolumns where id = object_id('docs')--select * from sysindexes --select * from sysindexkeys
----查询表中自动增长的字段,没有为空,如果有就只有一个----docs为表名 -- sql2000
SELECT a.name column_name,b.name data_typeFROM syscolumns a,systypes bWHERE a.id=object_id('docs') and a.xtype = b.xusertype AND a.autoval is not null
-------- sql2005
select a.Namefrom syscolumns a left join sysobjects b on a.iD=b.parent_obj and b.xtype='PK'where a.ID=object_id('docs') and a.status=0x80
----For mssql2005
SELECT 表名=case when a.colorder=1 then d.name else '' end, 表说明=case when a.colorder=1 then isnull(f.value,'') else '' end, 字段序号=a.colorder, 字段名=a.name, 标识=case when COLUMNPROPERTY(a.id,a.name,'IsIdentity')=1 then '1' else '' end,主键=case when exists(SELECT 1 FROM sysobjects where xtype='PK' and name in(SELECT name FROM sysindexes WHERE indid in(SELECT indid FROM sysindexkeys WHERE id = a.id AND colid=a.colid))) then '1' else '' end,类型=b.name,占用字节数=a.length,长度=COLUMNPROPERTY(a.id,a.name,'PRECISION'),小数位数=isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0),允许空=case when a.isnullable=1 then '1' else '' end,默认值=isnull(e.text,''),字段说明=isnull(g.[value],'')FROM syscolumns aleft join systypes b on a.xtype=b.xusertype inner join sysobjects d on a.id=d.id and d.xtype='U' and d.name<>'dtproperties' left join syscomments e on a.cdefault=e.id left join sys.extended_properties g on a.id=g.major_id and a.colid=g.minor_id left join sys.extended_properties f on d.id=f.major_id and f.minor_id =0 --where d.name='classinfo' --如果只查询指定表,加上此条件 order by a.id,a.colorder
----For mssql2000
SELECT 表名=d.name,--case when a.colorder=1 then d.name else '' end,字段序号=a.colorder,字段名=a.name,标识=case when COLUMNPROPERTY( a.id,a.name,'IsIdentity')=1 then '√'else '' end,主键=case when exists(SELECT 1 FROM sysobjects where xtype='PK' and name in (SELECT name FROM sysindexes WHERE indid in( SELECT indid FROM sysindexkeys WHERE id = a.id AND colid=a.colid))) then '√' else '' end,类型=b.name,占用字节数=a.length,长度=COLUMNPROPERTY(a.id,a.name,'PRECISION'),小数位数=isnull(COLUMNPROPERTY(a.id,a.name,'Scale'),0),允许空=case when a.isnullable=1 then '√'else '' end,默认值=isnull(e.text,''),字段说明=isnull(g.[value],'')FROM syscolumns aleft join systypes b on a.xtype=b.xusertypeinner join sysobjects d on a.id=d.id and d.xtype='U' and d.name<>'dtproperties'left join syscomments e on a.cdefault=e.idleft join sysproperties g on a.id=g.id and a.colid=g.smallid order by a.id,a.colorder
发表评论
最新留言
能坚持,总会有不一样的收获!
[***.219.124.196]2025年04月18日 04时54分48秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
Jenkins 集成postman 自动化运行接口测试用例
2019-03-06
hashlib 简单加密
2019-03-06
python装饰器实现对异常代码出现进行监控
2019-03-06
轮评审用例,写用例的重要性-----(python单元测试反思)
2019-03-06
django+appium实现UI自动化测试平台(开源部分,可定制开发)
2019-03-06
PAT 1008. Elevator (20)
2019-03-06
蓝桥杯 密码脱落 LCS
2019-03-06
第七届C/C++B-方格填数 DFS
2019-03-06
数据结构课设--3哈夫曼编码译码系统(树应用)
2019-03-06
pku 1061 青蛙的约会 扩展欧几里得
2019-03-06
Spring Boot 2.4 配置文件将加载机制大变化
2019-03-06
WPF之全局快捷键
2019-03-06
javascript 用函数语句和表达式定义函数的区别
2019-03-06
基于react hooks,antd4 配置生成表单并自动排列
2019-03-06
也来玩玩 javascript对象深拷贝,浅拷贝
2019-03-06
Kubernetes实战总结 - 动态存储管理StorageClass
2019-03-06
Django实战总结 - 快速开发一个Web服务
2019-03-06
【DG】主rac + 备rac dg 部署
2019-03-06
Oracle一次缩小表空间的处理过程
2019-03-06