统共分三步
第1步:创建一个表,用来存储包含该值的数据表和列名
CREATE TABLE dest (
table_name VARCHAR (60),
column_name VARCHAR (60)
);
第2步:拼接insert语句
SELECT
concat(
'insert into dest select ''',
table_name,
''',''',
column_name,
''' from ',
table_name,
' where ',
column_name,
' = ''所查值'' limit 1;'
)
FROM
information_schema. COLUMNS
WHERE
table_schema = '数据库名'
AND data_type = 'varchar' --所查值的数据类型
第3步:执行insert语句,将符合条件的数据表和列名存储到步骤1创建的数据表中
步骤2的执行结果,如下所示:
insert into dest select 'dde_ecu_config_info','factory_code' from dde_ecu_config_info where factory_code = '所查值' limit 1;
更多推荐
sql查询数据库中包含某个值的所有表
发布评论