Mysql查询特定值是哪些表哪些字段
摘自网上
-- 查询整个数据库中某个特定值所在的表和字段的方法
# flush tables; -- 创建表来存储查询结果 drop table if exists tmp_table; CREATE TABLE tmp_table ( tablename VARCHAR(1024) null, columnname VARCHAR(1024) null, columnvalue VARCHAR(1024) null ); DROP PROCEDURE IF EXISTS search_value; DELIMITER $$
-- v1内容值
CREATE PROCEDURE search_value(v1 VARCHAR(1024))
BEGIN DECLARE done INT DEFAULT 0;
DECLARE m_table VARCHAR(64);
DECLARE m_column VARCHAR(64); -- 查询数据库字段类型为'varchar' 的字段
DECLARE m_tables CURSOR
FOR
select table_name, column_name
from information_schema.columns
where data_type = 'varchar'
-- 注意修改这里的 table_schema
and table_schema = 'table_schema'
-- and table_name = 'biz_patient_register'
;
declare continue handler for not FOUND set done = 1; set @_v = v1;
open m_tables;
FETCH m_tables
INTO m_table, m_column;
WHILE done != 1 do
# insert into tmp_table select m_table as tablename, m_column as columnname, v1 as columnvalue;
set @m_sql = concat('insert into tmp_table select ''', m_table, ''' as tablename,''', m_column,
''' as columnname,`', m_column, '` as columnvalue from `', m_table, '` where `', m_column,
'` = ''%', v1, '%'';');
-- 编译sql
prepare stmt from @m_sql; -- 执行sqL
EXECUTE stmt;
deallocate prepare stmt;
# select m_table, m_column;
FETCH m_tables
INTO m_table, m_column;
END WHILE; CLOSE m_tables;
End $$
DELIMITER ; -- 存储过程创建完成
call search_value('152'); -- 执行存储过程
select *
from tmp_table; -- 查询存储过程执行的结果
Mysql查询特定值是哪些表哪些字段的更多相关文章
- mysql查询更新时的锁表机制分析
		
为了给高并发情况下的mysql进行更好的优化,有必要了解一下mysql查询更新时的锁表机制. 一.概述 MySQL有三种锁的级别:页级.表级.行级.MyISAM和MEMORY存储引擎采用的是表级锁(t ...
 - [SQL]查询整个数据库中某个特定值所在的表和字段的方法
		
查询整个数据库中某个特定值所在的表和字段的方法 当数据库做的太庞大的时候,难免会出现忘记哪个值会存入哪个表的情况,于是在网上找到的如下解决办法. 通过做一个存储过程,只需要传入一个想要查找的值,即可查 ...
 - mysql查询更新时的锁表机制分析(只介绍了MYISAM)
		
为了给高并发情况下的mysql进行更好的优化,有必要了解一下mysql查询更新时的锁表机制. 一.概述 MySQL有三种锁的级别:页级.表级.行级.MyISAM和MEMORY存储引擎采用的是表级锁(t ...
 - MySQL 给已存在的数据表 增加字段和注释
		
MySQL 给已存在的数据表 增加字段和注释 问题描述 在开发一个系统的过程中,经常会遇到随着系统服务功能的扩展,或者服务之间的关联,需要适当的修改原有的表结构,比如,增加一些必要的字段. 示例:在已 ...
 - MySQL查询结果复制到新表(更新、插入)
		
MySQL中可以将查询结果复制到另外的一张表中,复制的话通常有两种情况,一种是更新已有的数据,另一种是插入一条新记录.下面通过例子来说明.首先构建两个测试表. 表t1: 表t2: 1.如果t2表中存在 ...
 - mysql数据库中指定值在所有表中所有字段中的替换
		
MySQL数据库: 指定值在数据库中所有表所有字段值的替换(存储过程): 1.写一个存储过程,查指定数据库中所有的表名: CREATE PROCEDURE init_replace(in orig_s ...
 - Mysql查询的一些操作(查表名,查字段名,查当月,查一周,查当天)
		
查询数据库中所有表名 select table_name from information_schema.tables where table_schema='tools' and table_typ ...
 - SQLSERVER查询整个数据库中某个特定值所在的表和字段的方法
		
这几天有业务部门需要使用一个SAP B1老系统 中的报表,但是由于此报表没有加时间条件,导致一旦开始查询 就会导致B1系统异常退出.由于报表对应的SQL 是存在数据库中,所以想通过查找到这个报表的S ...
 - mysql查询关键字补充与多表查询
		
目录 查询关键字补充 having过滤 distinct去重 order by排序 limit分页 regexp正则 多表查询 子查询 连表查询 查询关键字补充 having过滤 关键字having和 ...
 
随机推荐
- TopCoder SRM502 Div1 500 贪心 01背包
			
原文链接https://www.cnblogs.com/zhouzhendong/p/SRM502-500.html SRM502 Div1 500 好题. 首先,如果已经确定了解决所有问题的优先级, ...
 - Codeforces 1000G Two-Paths 树形动态规划 LCA
			
原文链接https://www.cnblogs.com/zhouzhendong/p/9246484.html 题目传送门 - Codeforces 1000G Two-Paths 题意 给定一棵有 ...
 - 042 spring boot在启动之后,自动关闭
			
在学校数据源的时候,还没有开始使用数据源,项目就关闭了. 为了学习数据源,就只能使用测试类. 但是,最近需要使用restful进行测试的时候,项目是关闭的,就很糟糕,不好进行测试. 1.日志如下: D ...
 - 001 大数据情况下linux的配置
			
一:配置的大纲 主要的配置有几个方面: 主机名 IP 网络映射 增加新用户 给新用户root的权限,方便实验 关闭防火墙 安全子系统需要关闭 二:主机名的配置 命令:vi /etc/sysconfig ...
 - MySQL查询本周、上周、本月、上个月份数据的sql脚本
			
2018-11-13 查询今天的数据 select * from 表名 where to_days(时间字段名) = to_days(now()); 查询昨天的数据 SELECT * FROM 表名 ...
 - HDU 4370 0 or 1 (01规划)【Dijkstra】||【spfa】
			
<题目链接> 题目大意: 一个n*n的01矩阵,满足以下条件 1.X12+X13+...X1n=12.X1n+X2n+...Xn-1n=13.for each i (1<i<n ...
 - Ajax技术使用(一)
			
Ajax技术使用 目录 AJAX介绍 XMLHttpRequest 请求和响应 onreadystatechange 事件 AJAX介绍 什么是 AJAX AJAX = 异步 JavaScript 和 ...
 - P2659 美丽的序列
			
P2659 美丽的序列对于当前的最小值,找到最大的左右边界,然后更新答案.用单调队列确定左右边界,O(n)做法. #include<iostream> #include<cstdio ...
 - 20172328《程序设计与数据结构》实验三 敏捷开发与XP实践报告
			
20172328<程序设计与数据结构>实验三 敏捷开发与XP实践报告 课程:<程序设计与数据结构> 班级: 1723 姓名: 李馨雨 学号:20172328 实验教师:王志强 ...
 - NiftyNet开源平台使用
			
NiftyNet是一款开源的卷积神经网络平台,专门针对医学图像处理分析,上一篇博客已经详细介绍了这个平台,接下来让我简单介绍一下目前我了解到的使用方法.更详细的使用方法.以及配置过程请查看NiftyN ...