Sql 语句。获取指定表的列名
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Sql 语句。获取指定表的列名相关的知识,希望对你有一定的参考价值。
其中不包含主键列、唯一直列和外键约束的。
--isnull函数:需要个参数,如果第一个参数为空,则赋值第二个参数。SELECT
--空格代表as关键字
( 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 ( SELECT COUNT(*)
FROM sysobjects
WHERE ( name IN (
SELECT name
FROM sysindexes
WHERE ( id = a.id )
AND ( indid IN (
SELECT indid
FROM sysindexkeys
WHERE ( id = a.id )
AND ( colid IN (
SELECT
colid
FROM
syscolumns
WHERE
( id = a.id )
AND ( name = a.name ) ) ) ) ) ) )
AND ( xtype = 'PK' )
) > 0 THEN 'true'
ELSE 'false'
END ) 主键 ,
b.name 类型 ,
a.length 占用字节数 ,
COLUMNPROPERTY(a.id, a.name, 'PRECISION') AS 长度 ,
ISNULL(COLUMNPROPERTY(a.id, a.name, 'Scale'), 0) AS 小数位数 ,
( CASE WHEN a.isnullable = 1 THEN 'true'
ELSE 'false'
END ) 允许空 ,
ISNULL(e.text, '') 默认值 ,
ISNULL(g.[value], '') AS 字段说明
--a代表列集合表:为每个表和视图中的每列返回一行,并为数据库中的存储过程的每个参数返回一行
--b代表列类型表:为数据库中定义的每种系统提供的数据类型和每种用户定义的数据类型返回一行。
FROM syscolumns a
LEFT JOIN systypes b ON a.xtype = b.xusertype
--d代表对象表:在数据库中创建的每个对象(例如约束、默认值、日志、规则以及存储过程)都对应一行
INNER JOIN sysobjects d ON a.id = d.id
AND d.xtype = 'U'
AND d.name <> 'dtproperties'
--e代表e.text是默认值:包含数据库中每个视图、规则、默认值、触发器、CHECK 约束、DEFAULT 约束和存储过程的项
LEFT JOIN syscomments e ON a.cdefault = e.id
--g代表g.[value]是字段说明:针对当前数据库中的每个扩展属性返回一行。
LEFT JOIN sys.extended_properties g ON a.id = g.major_id
AND a.colid = g.major_id
ORDER BY a.id ,
a.colorder
这个方法可以获取当前库存中所有表的所有列。希望对你有用。 参考技术A 查询dba_tab_columns
如:
select column_name
from dba_tab_columns
where
owner=upper('xxx')
and
table_name=upper('yyy')
;
如果表名的区分大小写的话,注意表名用双引号,如:
select
column_name
from dba_tab_columns
where owner=upper('xxx')
and
table_name="MyTable"
;
亲测无误。本回答被提问者和网友采纳 参考技术B sp_help 表名
sql语句关于时间与时间戳
蓝色抹黑的是表的列名,但是里面数据的可是是2014-11-17,没办法和时间戳对比,请问怎么修改才能让另个数据进行对比
$dqtime = date(\'Y-m-d\',time());这种方法将当前时间转换为指定时间格式,然后可以比较两个时间大小
追问两个时间可以用>比较大小吗
追答mysql 中是可以的,它会当做两个字符串作比较,其他数据库你试下
追问好像不行哦,用了qqrwtjrwsj>\'$dqtime\',所有数据全被修改了,不管时间有没有大于当前时间的
追答分别输出下qqrwtjrwsj的值和$dqtime的值看下
参考技术A 你可以把 $dqtime中存储的数据转换成 2014-11-17格式的字符,然后进行比较。或者把 数据库中的字段转换成日期时间,进行比较(这个要看具体的数据库系统,转换方法不一样)
以上是关于Sql 语句。获取指定表的列名的主要内容,如果未能解决你的问题,请参考以下文章
用sql 语句 怎么样查询一张表的所有内容 和 另一张表的部分内容? 求解
Oracle-18-select语句初步&SQL中用算术表达式&别名的使用&连接运算符%distinct&where子句