鱼C论坛

 找回密码
 立即注册
查看: 561|回复: 0

[mysql] (五)存储过程

[复制链接]
发表于 2023-4-3 17:38:23 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 yukari123 于 2023-4-3 19:18 编辑

存储过程三大作用:

储存和管理SQL代码 Store and organize SQL
性能优化 Faster execution
数据安全 Data security

创建存储
右键选择 Create Stored Procedure,填空,Apply。
  1. CREATE PROCEDURE 'get_payments' ()
  2. BEGIN
  3.         SELECT * FROM payments;
  4. END
复制代码


删除存储过程
  1. DROP PROCEDURE IF EXISTS new_procedure;
复制代码


参数
  1. USE sql_invoicing;

  2. DROP PROCEDURE IF EXISTS get_invoices_by_client ;

  3. DELIMITER $$

  4. CREATE PROCEDURE get_invoices_by_client
  5. (
  6.     client_id INT  -- 为何不写INT(11)?
  7. )
  8. BEGIN
  9. SELECT *
  10. FROM invoices i
  11. WHERE i.client_id = client_id;
  12. END$$

  13. DELIMITER ;


  14. CALL get_invoices_by_client(1);
复制代码


带默认值的参数
  1. CREATE PROCEDURE `获取信息` (
  2. clients int,
  3. payment_method tinyint
  4. )
  5. BEGIN
  6.         select *
  7.     FROM payment p
  8.     where p.client_id=ifnull(client_id,p.client_id)and p.payment_method=ifnull(payment_method,p.payment_method);
  9.    
  10. END
复制代码



参数验证

  1. IF 错误参数条件表达式 THEN
  2.     SIGNAL SQLSTATE '错误类型'
  3.         [SET MESSAGE_TEXT = '关于错误的补充信息']
复制代码


输出参数

评分

参与人数 1荣誉 +3 鱼币 +3 收起 理由
歌者文明清理员 + 3 + 3 感谢楼主无私奉献!

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-28 01:35

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表