首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >列名如下的sql select

列名如下的sql select
EN

Stack Overflow用户
提问于 2011-03-11 23:09:53
回答 8查看 151.4K关注 0票数 39

我有一个列名为a1,a2...,b1.b2...的表。

如何选择列名类似于a%的所有类型

EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2011-03-11 23:11:41

您不能使用标准SQL。列名与SQL中的数据不同。

如果您使用的SQL引擎具有存储列名称、类型等的元数据表,则可以在该表上进行选择。

票数 1
EN

Stack Overflow用户

发布于 2011-03-11 23:15:51

这将为您提供列表

代码语言:javascript
复制
select * from information_schema.columns 
where table_name='table1' and column_name like 'a%'

如果你想用它来构造一个查询,你可以这样做:

代码语言:javascript
复制
declare @sql nvarchar(max)
set @sql = 'select '
select @sql = @sql + '[' + column_name +'],'
from information_schema.columns 
where table_name='table1' and column_name like 'a%'
set @sql = left(@sql,len(@sql)-1) -- remove trailing comma
set @sql = @sql + ' from table1'
exec sp_executesql @sql

请注意,以上代码是为SQL Server编写的。

票数 75
EN

Stack Overflow用户

发布于 2011-03-11 23:15:02

您需要使用视图INFORMATION_SCHEMA.COLUMNS

代码语言:javascript
复制
select COLUMN_NAME from INFORMATION_SCHEMA.COLUMNS where TABLE_NAME = my_table_name AND COLUMN_NAME like 'a%'

要内联行,可以使用PIVOT和执行EXEC()函数。

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5274594

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档