求助,关于工资管理中动态项目的处理,谢谢

mx_ch 2002-10-28 03:11:12
我现在设置了两个表,一个是存储工资数据的表结构如下:
col_1,col_2,col_3,col_4.....col_50
另一个表结构如下:
col_name,col_zn,use_YN,代表的意义分别是,col_name第一个表中的各字段名(col_1....col_50),col_zn表示用户自定义的工资项目,use_YN是一个是否使用的标记。
我想问一下,怎么才能够根据用户自定义的工资项目,建立输入工资数据的数据窗口。。
实际上我就是想实现把存储工资数据的字段名col_1...col_50显示为用户输入的工资项目
谢谢。。。
...全文
68 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
pufan 2002-10-29
  • 打赏
  • 举报
回复
用动态datawindow.
根据col_zn中项目的个数名称动态创建datawindow即可.
LittleDot88 2002-10-29
  • 打赏
  • 举报
回复
我的工资管理跟你类似,我处理如下:
1.将表一的所有字段做成一个DW
2.在程序中写语句,判断动态项目是否显示,若显示则显示成col_zn的值。
int i
string ls_col1,ls_col2,ls_use
for i=1 to 50
ls_col1='col_'+string(i)
select col_zn,use_yn into :ls_col2,:ls_use from table2 wherecol_name=:ls_col1;
if sqlca.sqlcode=0 then
if ls_use='y' then//显示
dw_1.modify(ls_col1+'.visible=1,'+ls_col1+'.text='+ls_col2)
else//隐藏
dw_1.modify(ls_col1+'.visible=0')
end if
else
messagebox('error!',sqlca.sqlerrtext)
end if
next

这样做的目的,主要是数据窗口可以事先调整好,从而美化数据窗口,

LittleDot88 2002-10-29
  • 打赏
  • 举报
回复
我的工资管理跟你类似,我处理如下:
1.将表一的所有字段做成一个DW
2.在程序中写语句,判断动态项目是否显示,若显示则显示成col_zn的值。
int i
string ls_col1,ls_col2,ls_use
for i=1 to 50
ls_col1='col_'+string(i)
select col_zn,use_yn into :ls_col2,:ls_use from table2 wherecol_name=:ls_col1;
if sqlca.sqlcode=0 then
if ls_use='y' then//显示
dw_1.modify(ls_col1+'.visible=1,'+ls_col1+'.text='+ls_col2)
else//隐藏
dw_1.modify(ls_col1+'.visible=0')
end if
else
messagebox('error!',sqlca.sqlerrtext)
end if
next

这样做的目的,主要是数据窗口可以事先调整好,从而美化数据窗口,

LittleDot88 2002-10-29
  • 打赏
  • 举报
回复
我的工资管理跟你类似,我处理如下:
1.将表一的所有字段做成一个DW
2.在程序中写语句,判断动态项目是否显示,若显示则显示成col_zn的值。
int i
string ls_col1,ls_col2,ls_use
for i=1 to 50
ls_col1='col_'+string(i)
select col_zn,use_yn into :ls_col2,:ls_use from table2 wherecol_name=:ls_col1;
if sqlca.sqlcode=0 then
if ls_use='y' then//显示
dw_1.modify(ls_col1+'.visible=1,'+ls_col1+'.text='+ls_col2)
else//隐藏
dw_1.modify(ls_col1+'.visible=0')
end if
else
messagebox('error!',sqlca.sqlerrtext)
end if
next

这样做的目的,主要是数据窗口可以事先调整好,从而美化数据窗口,

ice2water 2002-10-29
  • 打赏
  • 举报
回复
用动态DW

动态创建数据窗原理及实现

在实际应用中,经常需要根据用户需求来动态创建数据窗,一般方法是这样的。

在一个window中加入一个数据窗控件,如dw_new,但是该数据窗没有data object,(空白的)
就可以用以下语法来创建:
dw_new.create(ls_syntax,ls_error) // 创建语法,错误信息
ls_syntax可以用以下三种方法来形成:

一、动态由sql语法创建:

// 连接到pb的example数据库
string ls_sql,ls_syntax,ls_error
ls_syntax = 'select * from department'
ls_syntax = sqlca.SyntaxFromSQL(ls_sql,'style(type=grid)',ls_error)
if len(ls_error) >0 then
messagebox('Error','SyntaxFromSQL Error:~r'+ls_error)
else
dw_new.create(ls_syntax,ls_error)
if len(ls_error) >0 then
MessageBox("Error", "Create have these errors: ~r" + ls_error)
else
dw_new.settransobject(sqlca)
dw_new.retrieve()
end if
end if

二、由另一个数据窗的syntax来创建

string ls_syntax,ls_error
ls_syntax = dw_test.describe('datawindow.syntax')
dw_new.create(ls_syntax,ls_error)
if ls_error <> '' then
messagebox('Create Error',ls_error)
else
dw_new.settransobject(sqlca)
dw_new.retrieve()
end if

三、读取psr文件来创建

样例
string ls_syntax,ls_error,ls_ret
ls_ret = char(13)+char(10) //回车键
int li_fileNum
long li_length
li_FileNum = FileOpen("efef.psr",Streammode!, read!, shared!, Replace!)

// 以下是pb5的代码
if li_filenum >0 then
FileSeek(li_FileNum, 158, FromBeginning!)
li_length = fileRead(li_filenum,ls_syntax)
end if
fileclose(li_filenum)
if li_length = 0 then return
ls_syntax = "release 5;"+ls_ret+ls_syntax

//截掉ls_syntax中的数据部分,5.0以"sparse(names="dept_name?) "作为参考位置
//6.0以html(作为参考位置

long pos1,pos2
pos1 = pos(ls_syntax,'sparse(names="',1)
pos2 = pos(ls_syntax,'"',pos1 +16)
ls_syntax = left(ls_syntax,pos1) + mid(ls_syntax,pos1 +1,pos2 - pos1 +1)

dw_New.create(ls_syntax,ls_error)

if ls_error <> '' then
messagebox('Create Error',ls_error)
else
dw_new.settransobject(sqlca)
dw_new.retrieve()
end if

//pb6,pb7的代码可以参照pb5自己写,只是文件头和数据窗结束标记不同而已。


流方
2000/05/09

sandorn 2002-10-29
  • 打赏
  • 举报
回复
网页无法显示
您要访问的网页存在问题,因此无法显示。

--------------------------------------------------------------------------------

请尝试下列操作:

打开 expert.csdn.net 主页,寻找指向所需信息的链接。
单击刷新按钮,或者以后重试。

HTTP 500-13 - 服务器太忙
Internet 信息服务

--------------------------------------------------------------------------------

技术信息(支持个人)


背景:
此时无法处理请求。通讯量超出 Web 站点的能力。


详细信息:
Microsoft 支持

610

社区成员

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

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