mysql 查询整个数据库中某个特定值所在的表和字段的方法 如何写存储过程?

sqlserver查询整个数据库中某个特定值所在的表和字段的方法在网上比比皆是,mysql的却没有,自己试着用mysql的语法来改?在mysql中运行还是有错,还请高人指点~

CREATE PROCEDURE checktable(valu VARCHAR(1024))
BEGIN

DECLARE v_sql VARCHAR(1024);
DECLARE v_table VARCHAR(64);
DECLARE v_column VARCHAR(64);
-- 这个用于处理游标到达最后一行的情况
declare stop int default 0;

CREATE TEMPORARY TABLE tmp_table (
tablename VARCHAR(64) ,
columnname VARCHAR(64)
)

-- 声明游标
declare cur_tables cursor for SELECT TABLE_NAME, COLUMN_NAME FROM information_schema.`COLUMNS` WHERE TABLE_SCHEMA='phpcmsv9' ORDER BY TABLE_NAME,COLUMN_NAME;
-- 声明游标的异常处理,设置一个终止标记
declare CONTINUE HANDLER FOR SQLSTATE '02000' SET stop=1;
-- 打开游标
OPEN cur_tables
-- 读取一行数据到变量
fetch cur_tables into tablename,columnname;
-- 这个就是判断是否游标已经到达了最后
while stop <> 1 do
-- 操作
SET v_sql = 'IF EXISTS(SELECT NULL FROM [' + v_table + '] '
SET v_sql = v_sql + 'WHERE RTRIM(LTRIM([' + v_column + '])) LIKE ''%' + valu + '%'') '
SET v_sql = v_sql + 'INSERT INTO tmp_table VALUES (''' + v_table + ''', '''
SET v_sql = v_sql + v_column + ''')'

call EXEC(v_sql)

-- 读取下一行的数据
fetch cur_tables into tablename,columnname;
end while; -- 循环结束
close cur_tables; -- 关闭游标
end;

SELECT *
FROM tmp_table

DROP TABLE tmp_table
End

-- CALL checktable('模块管理')

好的,楼主,那么我们开始吧:
语句:
select * from shop where price in(select max(price) from shop group by article);

结果,请看图-------
温馨提示:内容为网友见解,仅供参考
无其他回答
相似回答