您的位置:首页 > 移动开发 > Objective-C

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

2013-05-27 19:11 651 查看
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 ;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: