mysql查看函数,存储过程操作
查询数据库中的存储过程和函数 方法一: select `name` from mysql.proc where db = \'your_db_name\' and `type` = \'PROCEDURE\' //存储过程 select `name` from mysql.proc where db = \'your_db_name\' and `type` = \'FUNCTION\' //函数 方法二: show procedure status; //存储过程 show function status; //函数 查看存储过程或函数的创建代码 show create procedure 存储过程名字; show create function 函数名字; 查看视图 SELECT * from information_schema.VIEWS //视图 SELECT * from information_schema.TABLES //表
mysql定时器,定时查询数据库,把查询结果插入到一张表中: 1、有两张表order_repayment_detail,msg_sim ,需要把前者中的按时间过滤出来的信息插入到短信发送表中,可以每晚12点钟查询执行一次查询。 创建存储过程,这里的存储过程主要提供给mysql的定时器event来调用去执行: create procedure mypro() BEGIN INSERT INTO `msg_sim` ( `tel`, `msg_content`, `title`, `msg_status`, `source`, `is_deleted`, `gmt_create`, `gmt_modified`) SELECT t.user_mobile, CONCAT("您有一笔", d.amount,"元账单须3天后还款!") as content ,"账单3天时提醒",1,1,0 ,SYSDATE(),SYSDATE() FROM order_repayment_detail d LEFT JOIN `order_info` t on t.order_no=d.order_no where d.bill_status!=2 and datediff(d.due_time,now())=3; end; 紧接着创建mysql的定时器event: create event if not exists eventJob on schedule every 1 second on completion PRESERVE do call mypro(); 这里设置为每一秒执行一次 ,可以在事件设计中修改计划 至此所有的准备工作已经写完了,做完这些,mysql要想利用定时器必须的做准备工作,就是把mysql的定时器给开启了: SET GLOBAL event_scheduler = 1; -- 启动定时器 SET GLOBAL event_scheduler = 0; -- 停止定时器 紧接着还要开启事件: ALTER EVENT eventJob ON COMPLETION PRESERVE ENABLE; -- 开启事件 ALTER EVENT eventJob ON COMPLETION PRESERVE DISABLE; -- 关闭事件 SHOW VARIABLES LIKE \'%sche%\'; -- 查看定时器状态 至此,你去数据库里面的表mytable里面看下,系统会每隔一秒去插入一条数据,嘻嘻,任务完成了。 select * from msg_sim