免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2231 | 回复: 9
打印 上一主题 下一主题

[问题解决了!!!]:mysql stored procedure 的问题。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-07-30 17:26 |只看该作者 |倒序浏览
我insert into client table 是 cno, clname, cpass, cdname, ccur, ccurname, crate, cbal, cbname1, cbano1, cbname2, cbano2, ct1, ct2, ct3, ct4, reg, ctype, odt, cby, lastup, lastuser, tstamp
insert 过后
select client 的 cno 然后我要insert into site_acc_order 的 cno

site_acc_order 是 cno, cdname, usr, commis, amt, cby, cdt, mby, mdt, stampt

不过select 不到 client 的 cno

  1. DELIMITER $$

  2. DROP PROCEDURE IF EXISTS `agent`.`addcom` $$
  3. CREATE DEFINER=`hang`@`%` PROCEDURE `addcom`(
  4.    in name1        varchar(20),
  5.    in pas          varchar(15),
  6.    in cid          integer(20),
  7.    in sessname     varchar(20),
  8.    in username     integer(20),
  9.    in commission   integer(20),
  10.    in amount       integer(20)
  11.   )
  12. Begin
  13.   declare ccurname1 varchar(5);
  14.   declare crate1 decimal(12,8);
  15.   declare cn integer(20);

  16. if not exists (SELECT clname FROM client WHERE clname=name1) then
  17.     select ccurname,crate into ccurname1,crate1 from ccur where ccurid=cid;
  18.     if (ccurname1 is null)then
  19.       rollback;
  20.     else
  21.       select ccurname1;
  22.       select crate1;
  23.       insert into client (clname,cpass,cdname,ccur,ccurname,crate,reg,ctype,cby,lastup,lastuser) values (name1,pas,name1,cid,ccurname1,crate1,'0','D',sessname,sysdate(),sessname);
  24.     end if;
  25. else
  26.   rollback;
  27. end if;
  28. #..........问题在这select不到 client 的 cno
  29.     select cno into cn from client WHERE cdname=name1;
  30.     if (cn is null)then
  31.       rollback;
  32.     else
  33.       select cn;
  34.       insert into site_acc_order (cno,cdname,usr,commis,amt,cby,cdt,mby,mdt) values (cn,name1,username,commission,amount,sessname,sysdate(),sessname,sysdate());
  35.     end if;
  36. #...........

  37. End $$

  38. DELIMITER ;
复制代码

if can leave yr msn or skype 4 me ...

[ 本帖最后由 dannylim86 于 2008-8-2 17:49 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2008-07-30 17:52 |只看该作者
Tell us your error occurred.

论坛徽章:
0
3 [报告]
发表于 2008-07-30 17:54 |只看该作者
#........
select cno into cn from client WHERE cdname=name1;
    if (cn is null)then
      rollback;
    else
      select cn;
      insert into site_acc_order (cno,cdname,usr,commis,amt,cby,cdt,mby,mdt) values (cn,name1,username,commission,amount,sessname,sysdate(),sessname,sysdate());
    end if;
#..........


no error but tis select cannot get the cno! T.T

[ 本帖最后由 dannylim86 于 2008-7-30 17:55 编辑 ]

论坛徽章:
0
4 [报告]
发表于 2008-07-31 18:04 |只看该作者
没有人会嘛???帮帮忙。。。

论坛徽章:
0
5 [报告]
发表于 2008-08-01 13:20 |只看该作者
原帖由 dannylim86 于 2008-7-31 18:04 发表
没有人会嘛???帮帮忙。。。



表结构贴出来!

论坛徽章:
0
6 [报告]
发表于 2008-08-01 23:13 |只看该作者
关注。。。。

论坛徽章:
0
7 [报告]
发表于 2008-08-02 11:25 |只看该作者
我insert into client table 是 cno, clname, cpass, cdname, ccur, ccurname, crate, cbal, cbname1, cbano1, cbname2, cbano2, ct1, ct2, ct3, ct4, reg, ctype, odt, cby, lastup, lastuser, tstamp
insert 过后
select client 的 cno 然后我要insert into site_acc_order 的 cno

site_acc_order 是 cno, cdname, usr, commis, amt, cby, cdt, mby, mdt, stampt

不过select 不到 client 的 cno

(大家帮帮忙 !!!)

论坛徽章:
0
8 [报告]
发表于 2008-08-02 11:37 |只看该作者
我的 call 在 PHP

<?

$mysqli->real_query ("CALL addcom('".$_REQUEST['U']."','123456','".$_REQUEST['ccurid']."','".$_SESSION['uname']."','".$_REQUEST['name']."','".$_REQUEST['comm']."','".$_REQUEST['amt']."');"

?>

论坛徽章:
0
9 [报告]
发表于 2008-08-02 15:01 |只看该作者
看得头好晕,你能把表结构show出来吗?再把你的需求写工整点:)

论坛徽章:
0
10 [报告]
发表于 2008-08-02 17:36 |只看该作者
谢谢大家我的问题解决了!!!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP