数据表

niuer09 2010-06-11 01:08:22
现有一informix数据表example,记录约+13w,共有十几个字段,现要提取其中的三个字段,设为A,B,C,条件是:
若有多条记录的A,B,C字段值完全相同,则只算一条提取。例如example内容如下:

ID A B C D E .. ..
-----------------------------------------
0 a 15 20 usa america
0 a 15 20 china asia
0 b 25 10 french eu
0 c 30 5 canada america
....

则提取结果应为
A B C
-------------------
a 15 20
b 25 10
c 30 5
...

给新提取的每一条记录设一编号(字段名为serialno,serial类型),格式如下

serialno A B C
---------------------------------
1 a 15 20
2 b 25 10
3 c 30 5
...

之后用该serialno更新example中的数据,如example更新完后的结果为
ID A B C D E .. ..
-----------------------------------------
1 a 15 20 usa america
1 a 15 20 china asia
2 b 25 10 french eu
3 c 30 5 canada america
....

不知说清楚了没。谢谢您的任何宝贵的意见!
...全文
38 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
niuer09 2010-06-13
  • 打赏
  • 举报
回复
问题已解决,谢谢~
souleditor 2010-06-13
  • 打赏
  • 举报
回复
create table tt
(
serialno serial,
D varchar(50),
E varchar(50),
F varchar(50)
);
insert into tt(D, E, F)
select A, B, C
from example
group by A, B, C;
update example
set ID = (
select serialno
from tt
where example.A = tt.D
and example.B = tt.E
and example.C = tt.F
);
drop table tt;

1,194

社区成员

发帖
与我相关
我的任务
社区描述
其他数据库开发 Informix
社区管理员
  • Informix社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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