pb10 第一行syntax error 求大佬康康

weixin_44229313 2020-12-14 04:16:39

如图 做的是工资管理系统里计算工资的按钮 错误里始终显示在第一行
呜呜呜大学生太菜了 求大佬

下接计算代码

integer r_yesno,r_row,r_count,r_rowcount,r_row1,r_gl1

string r_zg_code,r_gzzh

integer r_gznl,r_jbcs,r_cdcs,r_bjcs,r_sjcs,r_kgcs //工作年龄、加班次数、迟到次数、病假次数、事假次数、旷工次数

decimal r_xse //销售额

decimal r_jbgz,r_glgz,r_zcgz,r_gwjt,r_gdbt,r_glgz1 //基本工资项目

decimal r_jbf,r_cdkk,r_bjkk,r_sjkk,r_kgkk,r_jj,r_jtf,r_bxf //变动工资项目

decimal r_jbf1,r_cdkk1,r_bjkk1,r_sjkk1,r_kgkk1,r_jj1 //变动工资中对应的加班费、迟到扣款、病假扣款、事假扣款、旷工扣款

decimal r_je,r_sl,r_sskcs,r_ynsdexx,r_ynsdesx,r_ynsde //个人所得税额相关(金额、税率、速算扣除数、应纳所得额下限、应纳所得额上限、应纳所得额)

decimal r_ynse,r_jbgzhz,r_kkhj,r_yfhj,r_dkse,r_sfhj //应纳税额、基本工资汇总、扣款合计、应发合计、代扣税额、实发合计

string r_gw_code,r_zc_code,r_jx_code,r_sb_code//职工类别、岗位、职称、绩效、社保

r_yesno=messagebox('提示','是否真的进行相关操作?',question!,yesno!,2)

if r_yesno=2 then return

r_count=dw_table.rowcount()

for r_row=1 to r_count

r_zg_code=dw_table.getitemstring(r_row,'zg_code')

select gw_code,zc_code

into :r_gw_code,:r_zc_code

from gz_zgxxb where zg_code=:r_zg_code;

choose case i_type

case 'gz_jbgzb' //基本工资表

//工龄工资

select gznl into :r_gznl from gz_zgxxb where zg_code=:r_zg_code;

select glgz into :r_glgz1 from gz_glgz where gl=:r_gznl;

r_glgz=r_gznl*r_glgz1

//岗位津贴

select gwjt into :r_gwjt from gz_gwjt where gw_code=:r_gw_code;

//职称工资

select zcgz into :r_zcgz from gz_zcgz where zc_code=:r_zc_code;

//固定补贴

select gdbt into :r_gdbt from gz_kkbtgd;

r_gznl=gf_null_0(r_gznl)

r_glgz=gf_null_0(r_glgz)

r_gwjt=gf_null_0(r_gwjt)

r_zcgz=gf_null_0(r_zcgz)

r_gdbt=gf_null_0(r_gdbt)

dw_table.setitem(r_row,'gznl',r_gznl)

dw_table.setitem(r_row,'gnzl',r_gznl)

dw_table.setitem(r_row,'gwjt',r_gwjt)

dw_table.setitem(r_row,'zcgz',r_zcgz)

dw_table.setitem(r_row,'gdbt',r_gdbt)


case 'gz_bdgzb' //变动工资表

//计算在职职工的加班费、迟到扣款、病假扣款、事假扣款、旷工扣款

select jbcs,cdcs,bjcs,sjcs,kgcs into :r_jbcs,:r_cdcs,:r_bjcs,:r_sjcs,:r_kgcs

from gz_kqb where zg_code=:r_zg_code;

select jbf,cdkk,bjkk,sjkk,kgkk

into :r_jbf1,:r_cdkk1,:r_bjkk1,:r_sjkk1,:r_kgkk1

from gz_kkbtgd;

r_jbf=r_jbcs*r_jbf1

r_cdkk=r_cdcs*r_cdkk1

r_bjkk=r_bjcs*r_bjkk1

r_sjkk=r_sjcs*r_sjkk1

r_kgkk=r_kgcs*r_kgkk1

//绩效计算 以销售额为依据提成

select xse into :r_xse from gz_xse where zg_code=:r_zg_code;

if r_xse<5000 then

select tcse into :r_jj1 from gz_jx where jx_code=01;

r_jj=r_jj1

elseif r_xse>=5000 and r_xse<8000 then

select tcse into :r_jj1 from gz_jx where jx_code=02;

r_jj=r_jj1

elseif r_xse>=8000 and r_xse<11000 then

select tcse into :r_jj1 from gz_jx where jx_code=03;

r_jj=r_jj1

else

select tcse into :r_jj1 from gz_jx where jx_code=04;

r_jj=r_jj1

end if

r_jbf=gf_null_0(r_jbf)

r_cdkk=gf_null_0(r_cdkk)

r_bjkk=gf_null_0(r_bjkk)

r_sjkk=gf_null_0(r_sjkk)

r_kgkk=gf_null_0(r_kgkk)

r_jj=gf_null_0(r_jj)

dw_table.setitem(r_row,'jbf',r_jbf)

dw_table.setitem(r_row,'cdkk',r_cdkk)

dw_table.setitem(r_row,'bjkk',r_bjkk)

dw_table.setitem(r_row,'sjkk',r_sjkk)

dw_table.setitem(r_row,'kgkk',r_kgkk)

dw_table.setitem(r_row,'jj',r_jj)


case else //工资汇总表

choose case i_type

case 'gzhzjs' //汇总工资计算

//将基本工资项目、变动工资项目插入到工资汇总表

select gzzh into :r_gzzh from gz_zgxxb where zg_code=:r_zg_code;

select jbgz,glgz,gwjt,gdbt,zcgz into :r_jbgz,:r_glgz,:r_gwjt,:r_gdbt,:r_zcgz

from gz_jbgzb where rq=:g_rq and zg_code=:r_zg_code;

select jbf,jj,jtf,cdkk,bjkk,sjkk,kgkk,bxf into :r_jbf,:r_jj,:r_jtf,:r_cdkk,:r_bjkk,:r_sjkk,:r_kgkk,:r_bxf

from gz_bdgzb where rq=:g_rq and zg_code=:r_zg_code;

select gzzh into :r_gzzh

from gz_zgxxb where zg_code=:r_zg_code;

r_jbgz=gf_null_0(r_jbgz)

r_glgz=gf_null_0(r_glgz)

r_gwjt=gf_null_0(r_gwjt)

r_gdbt=gf_null_0(r_gdbt)

r_zcgz=gf_null_0(r_zcgz)

r_jtf=gf_null_0(r_jtf)

r_jbf=gf_null_0(r_jbf)

r_jj=gf_null_0(r_jj)

r_cdkk=gf_null_0(r_cdkk)

r_bjkk=gf_null_0(r_bjkk)

r_kgkk=gf_null_0(r_kgkk)

r_sjkk=gf_null_0(r_sjkk)

r_bxf=gf_null_0(r_bxf)

dw_table.setitem(r_row,'gzzh',r_gzzh)

dw_table.setitem(r_row,'jbgz',r_jbgz)

dw_table.setitem(r_row,'glgz',r_glgz)

dw_table.setitem(r_row,'gwjt',r_gwjt)

dw_table.setitem(r_row,'gdbt',r_gdbt)

dw_table.setitem(r_row,'zcgz',r_zcgz)

dw_table.setitem(r_row,'jtf',r_jtf)

dw_table.setitem(r_row,'jbf',r_jbf)

dw_table.setitem(r_row,'jj',r_jj)

dw_table.setitem(r_row,'cdkk',r_cdkk)

dw_table.setitem(r_row,'bjkk',r_bjkk)

dw_table.setitem(r_row,'sjkk',r_sjkk)

dw_table.setitem(r_row,'kgkk',r_kgkk)

dw_table.setitem(r_row,'bxf',r_bxf)

//计算在职职工的基本工资汇总,扣款合计,应发合计

r_jbgzhz=r_jbgz+r_glgz+r_gwjt+r_gdbt+r_zcgz

r_kkhj=r_cdkk+r_bjkk+r_sjkk+r_kgkk+r_bxf

r_yfhj=r_jbgzhz+r_jbf+r_jj+r_jtf

//计算代扣税额,实发合计

if r_yfhj<3000 then

r_dkse=0

else

r_ynse=r_yfhj - r_je

select count(*) into :r_rowcount from gz_grsdsl;

for r_row1=1 to r_rowcount

select ynsdexx,ynsdesx into :r_ynsdexx,:r_ynsdesx

from gz_grsdsl where sdsl_name=:r_row1;

if r_ynsdexx<r_ynse and r_ynsdesx>=r_ynse then

select sl,sskcs into :r_sl,:r_sskcs

from gz_grsdsl where sdsl_name=:r_row1;

r_dkse=r_ynse*(r_sl) - r_sskcs

end if

next

end if

r_sfhj=r_yfhj -r_dkse - r_kkhj

r_jbgzhz=gf_null_0(r_jbgzhz)

r_dkse=gf_null_0(r_dkse)

r_yfhj=gf_null_0(r_yfhj)

r_kkhj=gf_null_0(r_kkhj)

r_sfhj=gf_null_0(r_sfhj)

dw_table.setitem(r_row,'jbgzhz',r_jbgzhz)

dw_table.setitem(r_row,'yfhj',r_yfhj)

dw_table.setitem(r_row,'dkse',r_dkse)

dw_table.setitem(r_row,'kkhj',r_kkhj)

dw_table.setitem(r_row,'sfhj',r_sfhj)


...全文
524 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
weixin_44229313 2020-12-14
  • 打赏
  • 举报
回复
谢谢大佬!!发现最后确实忘记写end choose 感恩!!!
鵗鵺 2020-12-14
  • 打赏
  • 举报
回复
你这没有end choose么,这个报错估计是条件语句,for循环啥的缺少对应结束模块吧
源码下载地址: https://pan.quark.cn/s/8d2c461c797c JavaWeb程序设计构成了掌握Web交互式应用程序开发的核心领域,对于初学者来说,精通这一技术具有决定性意义。在“JavaWeb程序设计(第三版)作业答案”中,我们可以预期获得针对该教材习题的一系列深入解析,从而协助学习者强化知识体系。 JavaWeb所包含的技术组件涵盖了Servlet、JSP(JavaServer Pages)、JDBC(Java Database Connectivity)以及各类框架如Spring MVC、Struts等。Servlet是Java平台提供的一种扩展服务器功能的接口,能够处理HTTP请并生成相应的反馈。JSP则是一种用于构建动态网页的工具,它支持开发者将HTML代码与Java代码进行整合编写,从而简化了Web应用程序的开发流程。 作业答案通常会涉及以下几个核心内容: 1. **Servlet基础**:可能包含Servlet生命周期、init(), service(), destroy()方法的应用,以及如何在web.xml文件中设定Servlet的映射关系。 2. **JSP基础**:JSP的九大内置对象,如request、response、session、application等的使用,以及EL(Expression Language)和JSTL(JavaServer Pages Standard Tag Library)的实际操作。 3. **HTTP协议理解**:GET和POST请方法的差异,请头与响应头的应用,以及会话管理的概念阐释。 4. **JDBC数据库操作**:与数据库建立连接,执行SQL指令,处理查询结果集,以及...
源码链接: https://pan.quark.cn/s/a4b39357ea24 斐讯K2是一款广受用户青睐的无线路由器,其运行表现稳定且具备较高的可操作性,在DIY爱好者群体中拥有极高的声誉。本资料将系统性地阐述斐讯K2的固件刷机方法及其关联的技术要点。固件升级是路由器爱好者改善设备性能、扩展功能的一种普遍手段,经由替换出厂固件,能够达成更加个性化的网络配置、增强安全防护等目标。斐讯K2固件资源库涵盖了多种知名的非官方固件,诸如Tomato Pheonix 不死鸟、高恪、PandoraBox 潘多拉等,这些固件均具备独特的优势,能够适配不同用户的需。 1. Tomato Pheonix 不死鸟:Tomato是一款立足于Linux的开源固件,以其精巧、高效而备受推崇。不死鸟版本是专门为华硕及斐讯路由器优化的分支,提供了卓越的QoS(服务质量)配置、详尽的图表监控以及便捷的固件升级途径。对于那些需要精准调控带宽和监测网络状态的用户而言,这是一个理想的选项。 2. 高恪:高恪固件是OpenWrt的定制化版本,着重于操作的便捷性和运行的可靠性,特别适合对路由器操作不甚熟悉的用户群体。它提供了一些实用的功能,例如内置的广告屏蔽、快速测速工具等,同时保留了OpenWrt的适应性。 3. PandoraBox 潘多拉:潘多拉盒是另一款基于OpenWrt的固件,它以丰富的插件库和强大的自定义潜力而闻名。用户能够依据个人需安装各类插件,实现更多功能,如远程接入、DDNS(动态域名解析服务)等。 4. 官方固件的纯净版本与定制版本:官方固件通常更侧重于稳定性,纯净版意味着未预置额外的应用或服务,适合注重稳定性的用户。定制版则可能包含了制造商的特色功能或优...

743

社区成员

发帖
与我相关
我的任务
社区描述
PowerBuilder 脚本语言
社区管理员
  • 脚本语言社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧