一条Sql语句获得所有表的详细资料
2012-04-24 18:46
281 查看
SELECT
表名 = 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 parent_obj=a.id 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, ' ')
FROM
syscolumns a
left join systypes b on a.xusertype=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
where
d.name= 'T_RyoikuTorikumiSub' --如果只查询指定表,加上此条件
--d.name like '%T_%' --查询有规则命名的部分表
order by
a.id,a.colorder
表名 = 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 parent_obj=a.id 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, ' ')
FROM
syscolumns a
left join systypes b on a.xusertype=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
where
d.name= 'T_RyoikuTorikumiSub' --如果只查询指定表,加上此条件
--d.name like '%T_%' --查询有规则命名的部分表
order by
a.id,a.colorder
相关文章推荐
- 一条删除所有表中数据的SQL语句
- 一条SQL语句面试题:求选修所有课程的学生
- 获得客户端详细信息以及每个进程的sql语句
- 提取数据库内所有表的字段详细说明的SQL语句
- sql工具:一条sql语句,查询sql server某个指定表的所有列及其属性
- 获得客户端详细信息以及每个进程的sql语句
- 一个叫 team 的表,里面只有一个字段name, 一共有4 条纪录,分别是a,b,c,d, 对应四个球队,现在四个球队进行比赛,用一条sql 语句显示所有可能的比赛组合.
- 返回数据库内所有表的字段详细说明的SQL语句 (转)
- 一条SQL语句面试题:求选修所有课程的学生
- php中mysql一条sql语句查询出所有符合条件的数据,该怎么写?
- 一条SQL语句面试题:求选修所有课程的学生
- 写了一条Sybase SQL语句,用于生成一个表中所有数据的插入记录的生成
- 返回数据库内所有表的字段详细说明的SQL语句 (转)
- 一条SQL语句查询数据库中的所有表、存储过程、触发器
- ORACLE中如何用一条SQL语句删除一个表中所有某个列的值为空的数据?
- 一条SQL语句查询无限递归树所有数据
- 获得所有表信息的SQL语句
- 一条SQL语句查询MS SQL Server数据库中的所有表、存储过程、触发器
- 资料 mybatis 一条语句 分页查询(同时获得符合条件的总记录数)
- sql工具:一条sql语句,查询sql server某个指定表的所有列及其属性 .