sql数据库在一个表里面,知道某个值"a",如何获取其所属列的列名

sql数据库在一个表里面,知道某个值"a",如何获取其所属列的列名,第1张

需要这样搜索的话,你的表肯定没建好,一般程序不建议这么搜。

一定要这么搜的话只能一列列遍历每个单元格的值。

得先知道所有列名和顺序,然后双重循环,外循环遍历列,内循环遍历单元格。

当内循环遍历到当前单元格值含a后,输出当前外循环列名,然后可跳出或继续循环。

当数据多的话,这样肯定不行的。

建议你再优化一下建表。

这个方法写在程序里的,不是直接的sql查询语句

insert into 表(T1)

select

case when 字段1 = 1 then '字段1,' else '' end +

case when 字段2 = 1 then '字段2,' else '' end +

case when 字段3 = 1 then '字段3,' else '' end +

case when 字段20 = 1 then '字段20,' else '' end

as T1

from 表

数据库中创建对象时,管理员也要对其进行取名

现在谈谈取名的一些技巧

一、表名大小写的控制一般情况下Oracle数据库中的表名或者列名是不区分大小写的

在创建表或者列的时候,即使管理员采用了小写的名字,数据库在将其保存到数据字典之前,会先将其转换为大写,再将他们保存到数据字典中

这也就是为什么我们取名使用小写的子母取名,但是下次查看表的名字的时候,却变成了大写

虽然说Oracle数据库中表与列等数据库对象对于大小写是不敏感的,但是如果数据库管理员确实有需要要让数据库系统对表的名字区分大小写,这也是可以做到的

通常情况下,如果把名字使用双引号括起来,则在Oracle数据字典中就会成为区分大小写的名字

不过笔者这里要提醒各位数据库管理员,虽然说从技术上可以让数据库系统强制取分大小写,但是在实际工作中,包括在内的绝大部分数据库管理员可能都不建议这么做

因为如果有混合的大小写存在,那么在引用这些表或者列名称的时候就需要特别的小心

因为即使用户或者数据库管理员有着过目不忘的本领,也很难准确的记住这些名称的大小写歌时

如果数据库管理员硬要这么做的话,那么很可能是自寻烦恼

在查询时或者其他作业时,要严格区分大小写那是一件很头疼的事情

为此,对于这个大小写的控制,笔者建议数据库管理员要谨慎使用

除非有充分的理由,否则的话,不要轻易使用这个双引号来控制大小写

这个双引号不仅可以用来控制大小写,还有一个比较特殊的作用,就是用引用一些特殊的字符

如在建立表格的时候,需要设置一个名牌号的字段

有些数据库管理员习惯使用num#类似的名称

这不会违反数据库的取名规则

不过在处理的时候会比较麻烦

如利用create语句建立表格的时候,需要给这个字段名称加上双引号

否则的话,执行这条语句的时候,数据库会拒绝执行并向用户提示错误信息

类似的特殊符号还包括一个$美元符号

他们在建立表格的时候,在语句中都需要使用双引号

不过字段建立好之后,在引用这些对象的时候,不需要使用双引号了

同理,虽然Oracle数据库支持这些特殊符号,但是笔者不鼓励数据库管理员在表或者列的取名中采取这些特殊的符号

这有可能给后续的引用带来不必要的麻烦

二、牢记取名空间在Oracle数据库中,跟其他的数据库不同,有一个叫做取名空间的概念

在同一个取名空间中,其名字不可以重复

如表与视图就共享同一个取名空间,为此就要求不仅表的名字不能够相同,而且表的名字与视图的名字也不能够相同

因为他们处于同一个取名空间

类似的,表与函数也是同处于一个表空间,为此他们也不能够同名

不过表与索引、表与约束等等却属于不同的取名空间

也就是说,表的名字可以与约束的名字相同

所以说,数据库管理员在给表等对象取名的时候,一定要了解哪些对象共享同一个名称空间

如果在同一个名称空间内的,即使对象不同(如视图与表),但是他们仍然不能够取相同的名字

为了避免同一个取名空间内重名的现象,笔者建立在取名的时候最好能够根据对象的不同加上对象的固有前缀

如大部分的数据库管理员,在给表取名的时候,一般不会表名前面加上表对象的前缀

但是在定义函数或者视图对象的时候,则会加上前缀

如在函数前面可能会加上FN的前缀,而在视图前面可能会加上vi的前缀

如此的话,在同一个取名空间内也不用担心对象重名的问题

不过无论怎么说,这个取名空间的概念数据库管理员必须牢记

即使在实际的工作中,可以通过前缀等手段轻易的避免这个陷阱,但是在Oracle数据库管理员的认证考试中,这个取名空间也是一个必要的知识点

所以无论从实际的工作还是认证考试的需要,对于这个取名空间管理员都必须要有一个清晰的认识

三、在表、索引、约束、列之间设置密切的联系在创建表的同时,可以给表中的某些列添加索引、约束等等

如在员工信息表中,会设置员工编号唯一性约束

在创建约束的时候,也需要对约束进行取名

虽然说也约束与表、列不属于同一个取名空间,所以在取名的时候基本上没有限制

但是为了后续使用的方便,笔者对约束的取名还有一个小小的建议

简单的说,就是给一个与表直接有关的其他对象具有该表的名字是一种好的做法

如现在有一张用户表名字叫做ad_user(在表名前面一般不加对象名,但是可以根据应用软件的模块设计加上模块的前缀),这种表中有一个字段叫做叫做vlaue,用来存储员工的编号

在表设计的时候,需要给这个字段加一个索引

那么这个索引的名字就可以取名为IDX_USER_VALUE(也就是索引前缀表名字段名的形式)

这么做有什么好处呢一是可以确保相关对象的名字不会重复

因为表的名字不会重复,所以将表的名字与列的名字一起组成某个对象的名字,那么其重复的几率可以说基本上没有

二是方便管理员阅读、理解、维护等等

一看到索引或者约束对象的名字时,就可以看到这个是索引或者约束是用在哪个表的那个字段上的

而且也可以知道这个约束是唯一性约束还是检查约束;索引时主键索引还是外键索引

给数据库管理员一目了然的感觉

这对于后续的维护、升级、调整、引用等等都提供了方便

虽然说Oracle数据库中表与列等数据库对象对于大小写是不敏感的,但是如果数据库管理员确实有需要要让数据库系统对表的名字区分大小写,这也是可以做到的

通常情况下,如果把名字使用双引号括起来,则在Oracle数据字典中就会成为区分大小写的名字

不过笔者这里要提醒各位数据库管理员,虽然说从技术上可以让数据库系统强制取分大小写,但是在实际工作中,包括在内的绝大部分数据库管理员可能都不建议这么做

因为如果有混合的大小写存在,那么在引用这些表或者列名称的时候就需要特别的小心

因为即使用户或者数据库管理员有着过目不忘的本领,也很难准确的记住这些名称的大小写歌时

如果数据库管理员硬要这么做的话,那么很可能是自寻烦恼

在查询时或者其他作业时,要严格区分大小写那是一件很头疼的事情

为此,对于这个大小写的控制,笔者建议数据库管理员要谨慎使用

除非有充分的理由,否则的话,不要轻易使用这个双引号来控制大小写

很简单,所有列名都不写就行了。

insert into #xsmx1

select customer,month1_quantity,month2_quantity,month3_quantity,

avg_quantity,wait_quantity from #xsmx

如果非要写列名,用拼接sql的方法吧,

exec('insert into #xsmx1 (客户名称,['+@month1+'],['+@month2+'],本月已发,月平均用量,本月待发量) select customer,month1_quantity,month2_quantity,month3_quantity,

avg_quantity,wait_quantity from #xsmx')

用CASE WHEN吧

Select CASE ColumnName WHEN NULL THEN '' ELSE COLUMNNAME END AS NewColumnName FROM Table

有些DB有IIF或IF函数,也可以。

Java中有个元数据,交MetaData,这个是记录数据库和表本身信息的信息,

ResultSet rs=stexecuteQuery("select from student2");

//获取结果集元数据

ResultSetMetaData rsmd=rsgetMetaData();

//总列数

int size=rsmdgetColumnCount();

//打印列名

for(int i=1;i<=size;i++)

{Systemoutprint(rsmdgetColumnName(i)+"\t");

}

Systemoutprintln();

//打印列在数据库中的类型

for(int i=1;i<=size;i++)

{

Systemoutprint(rsmdgetColumnTypeName(i)+"\t");

}

Systemoutprintln();

//打印列的类型大小

for(int i=1;i<=size;i++)

{

Systemoutprint(rsmdgetColumnDisplaySize(i)+"\t");

}

Systemoutprintln();

//别名

for(int i=1;i<=size;i++)

{

Systemoutprint(rsmdgetColumnLabel(i)+"\t");

}

Systemoutprintln();

//打印结果集中数据

while(rsnext())

{

for(int i=1;i<=size;i++)

{

Systemoutprint(rsgetString(i)+"\t");

}

Systemoutprintln();

}

希望对你有用

以上就是关于sql数据库在一个表里面,知道某个值"a",如何获取其所属列的列名全部的内容,包括:sql数据库在一个表里面,知道某个值"a",如何获取其所属列的列名、SQL 如何根据指定值获取列名、如何为数据库取名等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9541124.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-29
下一篇 2023-04-29

发表评论

登录后才能评论

评论列表(0条)

保存