鱼C论坛

 找回密码
 立即注册
查看: 441|回复: 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。
CREATE PROCEDURE 'get_payments' ()
BEGIN 
        SELECT * FROM payments;
END

删除存储过程
DROP PROCEDURE IF EXISTS new_procedure;

参数
USE sql_invoicing;

DROP PROCEDURE IF EXISTS get_invoices_by_client ;

DELIMITER $$

CREATE PROCEDURE get_invoices_by_client
(
    client_id INT  -- 为何不写INT(11)?
)
BEGIN
SELECT * 
FROM invoices i
WHERE i.client_id = client_id;
END$$

DELIMITER ;


CALL get_invoices_by_client(1);

带默认值的参数
CREATE PROCEDURE `获取信息` (
clients int,
payment_method tinyint
 )
BEGIN
        select *
    FROM payment p
    where p.client_id=ifnull(client_id,p.client_id)and p.payment_method=ifnull(payment_method,p.payment_method);
    
END


参数验证
IF 错误参数条件表达式 THEN
    SIGNAL SQLSTATE '错误类型'
        [SET MESSAGE_TEXT = '关于错误的补充信息']

输出参数

评分

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

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-22 04:27

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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