C 知道
数据库的一个表(A表)中有多个字段,这些字段存的都是一个code值,而这些coede对应的value值存在一个枚举表里,现在想要查这个A表,要求返回的需要是这些code对应的Value值,该怎么查。就是这个枚举表里有很多个不同字段的value值和code值,其他表只存这个code值,需要根据这个code值来枚举表里找对应的value值,该怎么找呢
收起
该回答引用GPTᴼᴾᴱᴺᴬᴵ可以使用SQL的JOIN操作来将枚举表和A表进行连接,从而返回code对应的value值。
假设枚举表的表名为enum_table,有两个字段:code和value,A表的表名为A_table,有两个字段:id和code。则可以使用以下语句查询A_table,并返回code对应的value值:
SELECT A_table.id, enum_table.valueFROM A_tableJOIN enum_table ON A_table.code = enum_table.code;
这个语句将会返回一个包含两个字段的结果集,第一个字段为A_table中的id值,第二个字段为enum_table中对应code的value值。
但是现在问题,这个枚举表不止有a表的这个字段,还有别的表的一些字段,也就是code值0 1 2 3不是唯一的。好几个表里好几个字段的value值都存在一个枚举表里,这个几个表这个字段的是code,也就是0 1 2等等,这些0 1 2 对应枚举表的value值。比如说年龄范围对应0 1 2 ,身高范围也会对应0 1 2
如果枚举表不止有a表的字段,还有其他表的字段,那么可以在查询时同时指定表名和字段名来查询对应的值。例如:
SELECT e.valueFROM enum_table eWHERE e.table_name = 'a'AND e.field_name = 'gender'AND e.code = 0;
如果其他表的字段也存在相同的code值,那么需要在查询时加上限制条件,例如通过表名和字段名来筛选出对应的值。
报告相同问题?
程序员都在用的中文IT技术交流社区
专业的中文 IT 技术社区,与千万技术人共成长
关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!