免费注册 查看新帖 |

Chinaunix

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

存储过程中运算符如何使用??? [复制链接]

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-10-10 14:10 |只看该作者 |倒序浏览
本帖最后由 y331044508 于 2011-10-10 17:30 编辑

informix 版本:15.6
  1. 创建table3
  2. CREATE TABLE table3
  3. (
  4.     yjid integer PRIMARY KEY,
  5.     mustyj float,
  6.     realityyj float,
  7.     percentyj float
  8. );
  9. insert into table3 (yjid,mustyj,realityyj,percentyj) values ('1','10','8.9','');
  10. insert into table3 (yjid,mustyj,realityyj,percentyj) values ('2','10','7.9','');
  11. insert into table3 (yjid,mustyj,realityyj,percentyj) values ('3','10','8.4','');
  12. insert into table3 (yjid,mustyj,realityyj,percentyj) values ('4','10','8.3','');
  13. insert into table3 (yjid,mustyj,realityyj,percentyj) values ('5','10','7.3','');
  14. --6、计算员工的业绩百分比
  15. drop procedure table_function;
  16. create procedure table_function()
  17.   yjid_v integer;
  18.         mustyj_v float;
  19.         realityyj_v float;
  20.         percentyj_v float;
  21.         let percentyj_v =''
  22. while percentyj_v =''
  23.         select first 1 yjid,mustyj,realityyj,percentyj into yjid_v,mustyj_v,realityyj_v,percentyj_v from table3 where percentyj='';
  24.         --计算出realityyj_v / mustyj_v = percentyj_v 这里如何写?
  25.         updata table2 set percentyj=percentyj_v where yjid=yjid_v;
  26. end while;
  27. end procedure;   
复制代码
刚开始学习这个,还希望前辈们多多指教,看看我这个存储写的是不是不够简洁。
再是希望能够给我说下具体的存储过程中如何使用运算符,谢谢。

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
2 [报告]
发表于 2011-10-10 14:29 |只看该作者
难道是我没表达清楚意思吗?怎么没人呢???

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
3 [报告]
发表于 2011-10-10 15:02 |只看该作者
realityyj_v / mustyj_v = percentyj_v   怎么计算出这个值呢  怎么写呢?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
4 [报告]
发表于 2011-10-10 17:31 |只看该作者
本帖最后由 y331044508 于 2011-10-10 17:32 编辑
  1. create procedure table_function()
  2.   define yjid_v integer;
  3.         define mustyj_v float;
  4.         define realityyj_v float;
  5.         define percentyj_v float;
  6.   define i integer;
  7.   define x integer;
  8.   select count(*) into i from table3 where percentyj is null;
  9. for x =1 to i
  10.         select first 1 yjid,mustyj,realityyj into yjid_v,mustyj_v,realityyj_v from table3 where percentyj is null;
  11.         let percentyj_v =realityyj_v/mustyj_v;
  12.         update table3 set percentyj=percentyj_v where yjid=yjid_v;
  13. end for;
  14. end procedure;
复制代码
搞了半天才搞出来

论坛徽章:
0
5 [报告]
发表于 2011-10-11 15:18 |只看该作者
let 变量=公式

btw: lz的informix版本很牛呀,穿越回来的?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP