欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

sp_object MYSQL获取当前实例下指定对象与定义语句内容_MySQL

程序员文章站 2022-04-29 08:24:46
...
bitsCN.com

sp_object MYSQL获取当前实例下指定对象与定义语句内容

[sql]

DELIMITER $$

USE `test`$$

DROP PROCEDURE IF EXISTS `sp_object`$$

CREATE PROCEDURE `sp_object` ( p_OBJECTNAME VARCHAR(255), p_DBNAME VARCHAR(255) )

BEGIN

/*

作者:陈恩辉

调用示例:

CALL sp_object ( 'UpdateFactAdGroupDailyUsageByHourly','' );

*/

-- 过程与函数

SELECT `type` AS __TYPE, db AS DBNAME ,`name` AS OBJECTNAME ,body AS DEFINITION

FROM mysql.proc a

WHERE db LIKE CONCAT(p_DBNAME,'%')

AND `name` LIKE CONCAT(p_OBJECTNAME, '%') -- AND `type` = 'PROCEDURE'

-- 表

UNION ALL

SELECT 'TABLE' AS __TYPE, TABLE_SCHEMA,TABLE_NAME ,'' AS DEFINITION

FROM information_schema.TABLES a

WHERE TABLE_SCHEMA LIKE CONCAT(p_DBNAME,'%')

AND table_name LIKE CONCAT(p_OBJECTNAME,'%')

-- 触发器

UNION ALL

SELECT 'TRIGGER' AS __TYPE ,TRIGGER_SCHEMA AS DBNAME ,TRIGGER_NAME ,ACTION_STATEMENT AS DEFINITION FROM information_schema.`TRIGGERS` a

WHERE TRIGGER_SCHEMA LIKE CONCAT(p_DBNAME,'%')

AND TRIGGER_NAME LIKE CONCAT(p_OBJECTNAME, '%')

-- 视图

UNION ALL

SELECT 'VIEW' AS __TYPE ,TABLE_SCHEMA AS DBNAME,TABLE_NAME AS `viewname`,VIEW_DEFINITION AS DEFINITION FROM information_schema.`VIEWS` a

WHERE TABLE_SCHEMA LIKE CONCAT(p_DBNAME,'%')

AND TABLE_NAME LIKE CONCAT(p_OBJECTNAME, '%')

ORDER BY __TYPE ,DBNAME ;

END$$

DELIMITER ;

bitsCN.com