mysql 查询整个数据库中某个特定值所在的表和字段的方法?

only1apple 2011-12-09 04:06:08
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('模块管理')
...全文
668 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
only1apple 2011-12-10
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 nicenight 的回复:]
这里生成的 sql 不是 mysql 的语法:

SQL code

SET v_sql = 'IF EXISTS(SELECT NULL FROM [' + v_table + '] '
SET v_sql = v_sql + 'WHERE RTRIM(LTRIM([' + v_column + '])) LIKE ''%' + valu + '%'') '
……
[/Quote]

执行到这一行已经报错了 DECLARE cur_tables CURSOR FOR
SELECT TABLE_NAME, COLUMN_NAME FROM information_schema.`COLUMNS`
我在想,是不是游标里不能引用其他数据库的表?
rucypli 2011-12-09
  • 打赏
  • 举报
回复
这个不了解业务而去便利所有的列里面的数据不太好吧


http://luoyahu.iteye.com/blog/837851
nicenight 2011-12-09
  • 打赏
  • 举报
回复
这里生成的 sql 不是 mysql 的语法:
    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)

56,940

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧