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

sqlserver查询整个数据库中某个特定值所在的表和字段的方法在网上比比皆是,mysql的却没有,自己试着用mysql的语法来改?在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('模块管理')
展开
 我来答
手机用户38835
2011-12-13
知道答主
回答量:67
采纳率:0%
帮助的人:29.7万
展开全部
好的,楼主,那么我们开始吧:
语句:
select * from shop where price in(select max(price) from shop group by article);

结果,请看图-------
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式