Mysql学习mysql带输出参数存储过程(代码与示例)

Mysql学习mysql带输出参数存储过程(代码与示例),第1张

概述介绍《Mysql学习mysql带输出参数存储过程(代码示例)》开发教程,希望对您有用。

《MysqL学习MysqL带输出参数存储过程(代码与示例)》要点:
本文介绍了MysqL学习MysqL带输出参数存储过程(代码与示例),希望对您有用。如果有疑问,可以联系我们。

导读:一个MysqL存储过程代码:CREATE defineR=`root`@`%` PROCEDURE `pro_query_payment_key`(IN `f_pID` varchar(20),IN `paychannel`...

一个MysqL存储过程代码:
 MysqL入门

CREATE defineR=`root`@`%` PROCEDURE `pro_query_payment_key`(IN `f_pID` varchar(20),IN `paychannel` int,IN `f_money` DECIMAL(10,2),OUT `result` int)
BEGIN
/*while 变量*/
declare i_arrCount int;
/*支付账户个数*/
declare arrCount int;
/*支付账户keys_ID*/
declare payment_keys varchar(200);
/*支付额度最小的账号ID*/
declare payment_key varchar(20);
/*当天支付账户已使用额度统计*/
declare order_sum decimal(8,2);
/*当天支付账户剩余额度*/
declare current_day_remanant_limit decimal(8,2);
/*变量初始化*/
set i_arrCount=0;
set arrCount=0;
set payment_keys = '';
set payment_key = '';
set order_sum = 0;
set result = 0;
set current_day_remanant_limit =0;
select keys_ID into payment_keys from iweb_payment_key where pID=f_pID and payment_ID=paychannel limit 1;MysqL入门

select (select sum(daylimit) from iwb_mer_account_limit where pID=f_pID)-(select ifnull(sum(transMoney),0) from iweb_orders where pID=f_pID and paychannel=paychannel and state=1 and  date(payTime)=date(Now()))
as remnant_limit into current_day_remanant_limit;MysqL入门

if f_money<=current_day_remanant_limit thenMysqL入门

if length(payment_keys)>0 then
select fun_split_total(payment_keys,',') into arrCount;
drop table if exists $temptable;
create table $temptable(
pay_key int DEFAulT 0,
orders_sum decimal(8,2)  DEFAulT 0
);
while i_arrCount<arrCount do
begin
set i_arrCount=i_arrCount+1;
select fun_split_string(payment_keys,i_arrCount) into payment_key;
select  ifnull(sum(transMoney),0) as transMoney into order_sum  from iweb_orders where pID=f_pID  and paychannel=paychannel and  date(payTime)=date(Now()) and payKey=payment_key and state=1;
insert into $temptable(pay_key,orders_sum) values(payment_key,order_sum);
end;
end while;
select ifnull(pay_key,0) into result from $temptable where orders_sum=(select min(orders_sum) from $temptable limit 1) limit 1;
drop table if exists $temptable;
end if;
else
select -1 into result;
end if;
end;
 
--//MysqL存储过程的调用示例
call  pro_query_payment_key(1000,5,@result);
select @result;MysqL入门

以上分享的这个MysqL存储过程,涉及到的知识点还是比拟多的,建议大家好好研究.MysqL入门

内存溢出PHP培训学院每天发布《MysqL学习MysqL带输出参数存储过程(代码与示例)》等实战技能,PHP、MysqL、liNUX、APP、Js,CSS全面培养人才。

总结

以上是内存溢出为你收集整理的Mysql学习mysql带输出参数存储过程(代码与示例)全部内容,希望文章能够帮你解决Mysql学习mysql带输出参数存储过程(代码与示例)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1153720.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存