设为首页
联系站长
加入收藏

您的位置: 首页>>IT业界>>互联网>>正文
 PowerBuilder中实现数据窗口动态排序的三种方法
 日期:2006-1-20 10:13:15  来源:百当软件园
一、 准备工作

  设计如图1所示的示例窗口。为了更好地比较三种不同的方法,dw—1中的数据来自两个表student和class。student表中包含四个字段sid(学号)、sname(姓名)、saddr(住址)和cid(班号),class表中包含两个字段cid(班号)和cname(班级名称)。


图1


二、三种方法的源程序

  三种方法中的“执行”按钮的代码分别为:

  方法1:
  用SetSQLselect()
  string ls—oldsql,ls—newsql,ls—order ls—column
  ls—oldsql=dw—1.getsqlselect()
  choose case ddlb—1.text
  case ″学号″ls—column=″sid″
  case ″姓名″ls—column=″sname″
  case ″住址″ls—column=″saddr″
  case ″班号″ls—column=″class.cid″
  case ″班级名称″ ls—column=″cname″
  end choose
  if rb—1.checked then ls—order=″ASC″
  else ls—order=″DESC″
  end if
  ls—newsql=ls—oldsql+″ ORDER BY ″+ &
  ls—column+″ ″+ls—order
  if dw—1.setsqlselect(ls—newsql)=-1 then
  messagebox(″警告″,″数据设置失败″,stopsign!)
  else dw—1.settransobject(sqlca)
  dw—1.reset()
  dw—1.retrieve()
  dw—1.setsqlselect(ls—oldsql)
  end if 

方法2:
  用describe()和modify()
  string ls—mod, ls—order,ls—old,ls—column
  ls—old=dw—1.describe(′datawindow.table.select′)
  dw—1.settransobject(sqlca)
  choose case ddlb—1.text
  case ″学号″ls—column=″sid″
  case ″姓名″ls—column=″sname″
  case ″住址″ls—column=″saddr″
  case ″班号″ls—column=″class.cid″
  case ″班级名称″ ls—column=″cname″
  end choose
  if rb—1.checked then ls—order=″ASC″
  else ls—order=″DESC″
  end if
  ls—mod=″datawindow.table.select=′ ″+ls—old+&
  ′ORDER BY ″ ′+ls—column+′ ″ ′+ls—order+″ ′ ″
  dw—1.modify(ls—mod)
  dw—1.retrieve()
  dw—1.modify(″datawindow.table.select= &
  ′ ″+ls—old+″ ′ ″) 

  方法3:
  用setsort()和sort()
  string ls—sort,ls—order,ls—column
  choose case ddlb—1.text
  case ″学号″ ls—column=″#1″
  case ″姓名″ ls—column=″#2″
  case ″住址″ ls—column=″#3″
  case ″班号″ ls—column=″#4″
  case ″班级名称″ ls—column=″#5″
  end choose
  if rb—1.checked then ls—order=″A″
  else ls—order=″D″
  end if
  ls—sort=ls—column+′′+ls—order
  dw—1.setsort(ls—sort)
  dw—1.sort() 

三、三种方法的比较

  1.第一种和第二种方法要求数据窗口在生成时是无序的,第三种方法无此要求。

  2.对于来自不同表单的相同的列名(如student.cid、class.cid)用第二种方法排序实现起来较麻烦,因为在用modify()函数时要特别注意引号的使用。但是第二种方法比第一种方法的执行速度要快。

  3.第三种方法使用起来最方便,既可以引用列名也可引用列号(如#4表示第四列)来指定序列。

相关文章

·用PB生成GUID解决主键重复
·用PowerBuilder编写邮件应用程序
·PowerBuilder的可执行文件所需的
·低级键盘钩子屏蔽Win键、Alt+Tab
·PowerBuilder中实现系统热键功能
·循序渐进学习Power Builder 6.0


阅读排行

·Win 2000不能访问Win XP的原因及
·解析Windows中的帐户和权限功能
·如何共享Windows XP操作系统
·Windows XP Service Pack 1
·通过 Windows XP 注册表自定义您
·Windows 2000 TCP/IP协议概述
·Windows 2000 Server TCP/IP协议
·dos常用命令使用说明
·Windows变慢原因分析及解决方法(
·Windows变慢原因分析及解决方法(
·WINXP下强行关闭“杀”不了的进程
·Windows XP系统注册表的恢复

最新文档

·创业激情需冷静 网络代理选择应理
·域名交易平台亟需规范 预防域名买
·Travel旅游域名即将引发抢注潮 
·从原理深处分析如何预防arp攻击
·突破建站弊端 企业网络营销大有可
·如何区分进程和病毒?
·java的基础知识,如何学好java
·微机原理与接口技术基础知识
·如何解决青少年沉迷网络的问题,
·全面分析主板BIOS报警信号

请您注意:
·尊重网上道德,遵守中华人民共和国的各项有关法律法规
·您在本站发表的作品,本站有权在网站内转载或引用
·其他网站如果需要转载 本站文章请在贵站著名来源,谢谢合作