PB中crosstab表继承上个tab中数据的问题

mike0392 2009-12-28 10:05:32
比如我现在的结果是(现在是动态列为年份,值是amount):
2006 2007 2008 2009
amount amount amount amount
3000 5000
可以看出2007和2009的数据为null,那么如果我要2007继承2006的amount数据,即3000;2009继承2008的5000,如何办到?
也就是说如果一年的amount为null,就自动继承前一年的数据。
表可以是静态也可以是动态的,在下是新手,请高手指教。
...全文
108 6 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
pb8 2009-12-28
  • 打赏
  • 举报
回复
根据这个数据再做数据窗口数据就会直接有了~~
pb8 2009-12-28
  • 打赏
  • 举报
回复

//测试数据
create table tb_xx(
company varchar(10) not null ,
amount numeric(10,2) null ,
year numeric(4) not null,
primary key(company,year)
);


insert into tb_xx(company,amount,year)
SELECT 'COMPANY A',3000,2006
union
SELECT 'COMPANY A',5000,2008
union
SELECT 'COMPANY B',2000,2007
union
SELECT 'COMPANY B',8000,2009;

//呵呵,查询的SQL

select c.company,b.year,amount=(select top 1 amount from tb_xx where company=c.company and year<=b.year order by year desc)
from tb_xx a,(select distinct year from tb_xx) b,(select distinct company from tb_xx)c
where a.year=*b.year and a.company=*c.company
order by c.company,b.year
不是导演李安 2009-12-28
  • 打赏
  • 举报
回复
mark~
mike0392 2009-12-28
  • 打赏
  • 举报
回复
简单说,sql是
select company,year,amount
from table_name
然后crosstab形式建datawindow,rows选company,columns选year,values选amount
就出来类似以下:
2006 2007 2008 2009
amount amount amount amount
company A 3000 5000
company B 2000 8000
而我要的结果是:
2006 2007 2008 2009
amount amount amount amount
company A 3000 3000 5000 5000
company B 2000 2000 8000
也就是如果本年度值为null,就继承上一年的。
这么说清楚了么?我实在找不到什么好的方法解决。。。。
pb8 2009-12-28
  • 打赏
  • 举报
回复
要把你基础数据提供出来才好写的,这样太抽象了点~~
mike0392 2009-12-28
  • 打赏
  • 举报
回复
貌似很神,去试试,等一下把分给你,谢谢了啊
select top 1 amount ....不知道还能这么写呢...
Powerbuilder 9.0实用教程》源代码 1.本源代码包括以下章节源代码: 第01章 认识PowerBuilder 9.0、第05章 创建应用程序、第06章 创建窗体、第07章 创建菜单和工具栏、第10章 应用程序的调试和发布、第11章 典型小型实例赏析、第12章 图书管理系统实例和第13章 学生选课系统实例。 2.源代码使用方法参见《附录A 源代码的使用方法》文件。 __________________________________________________________________ 注意: 1.建议读者下载源文件后,将该源文件进行备份,读者使用副本源文件进行学习,这样一但出问题就不用再从网上下载了。 2.将源文件数据库文件”文件夹一定要复制到C盘根目录下,这样才能保证您连接数据库文件成功,具体方法参见《附录A 源代码的使用方法》。 对于书源代码除了数据库外其他都能正常使用,而示例数据库需要用户在自己的计算机上注册后才能使用,如果不注册数据源就运行应用程序是检索不到任何数据的,下面以连接学生选课系统数据库为例具体介绍如何连接数据库文件。 第1章 认识PowerBuilder 9.0 1 1.1 PowerBuilder 9.0简介 1 1.1.1 国软件业现状 1 1.1.2 为什么要学习PowerBuilder 9.0 2 1.1.3 PowerBuilder的概述 2 1.1.4 PowerBuilder的特点 3 1.1.5 PowerBuilder 9.0的新特性 6 1.2 安装PowerBuilder 9.0软硬件需求 9 1.2.1 软件环境需求 9 1.2.2 硬件环境需求 9 1.3 PowerBuilder 9.0功能界面介绍 10 1.3.1 PowerBuilder 9.0界面简介 10 1.3.2 常用功能菜单 10 1.4 工作环境设置 16 1.4.1 工具栏的设置 16 1.4.2 窗口排列 19 1.4.3 快捷键设置 20 1.4.4 系统选项设置 21 1.5 用5分钟制作一个简单实例 22 1.5.1 实例运行界面 22 1.5.2 新建一个工作空间对象 22 1.5.3 新建一个应用程序对象 23 1.5.4 创建窗体 23 1.5.5 为应用程序添加open事件代码 25 1.6 小结 27 1.7 习题 27 第2章 编程基础知识 28 2.1 PowerScript脚本语言书写规则 28 2.1.1 忽略大小写 28 2.1.2 语句的断行、续行和分割 28 2.1.3 注释 29 2.2 数据类型 29 2.3 变量和作用域 30 2.3.1 定义变量 30 2.3.2 引用变量 30 2.3.3 变量的作用域 30 2.4 操作符 31 2.5 标识符 32 2.5.1 标识符的构成 32 2.5.2 匈牙利命名法 32 2.6 常用代词 33 2.7 控制语句 34 2.7.1 判断语句 34 2.7.2 循环语句 36 2.8 结构 38 2.8.1 创建结构 38 2.8.2 使用结构 40 2.9 函数 40 2.9.1 Open()和Close()函数 41 2.9.2 MessageBox()函数 41 2.9.3 类型转换函数 41 2.9.4 类型判断函数 42 2.9.5 其他函数 42 2.10 ODBC数据源与专用数据库接口 43 2.10.1 什么是ODBC数据源 43 2.10.2 专用数据库接口 43 2.10.3 连接数据库 44 2.10.4 配置ODBC 48 2.11 SQL语言 49 2.11.1 SQL语言的格式 49 2.11.2 在PowerBuilder 9使用SQL语句 51 2.12 类和对象的概念 56 2.12.1 继承 57 2.12.2 重载和多态性 57 2.12.3 封装 57 2.12.4 属性、事件和函数 57 2.13 在PowerBuilder 9.0实现面向对象编程 58 2.13.1 创建对象 58 2.13.2 设置对象属性 59 2.13.3 编写事件代码 59 2.13.4 实现继承对象 60 2.14 用户对象和用户事件 61 2.14.1 用户对象分类 61 2.14.2 定义用户对象 62 2.14.3 使用用户对象 64 2.14.4 用户事件 66 2.15 小结 67 2.16 习题 68 第3章 创建数据库 69 3.1 数

611

社区成员

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

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