当前位置: 代码迷 >> Informix >> 数据表,该怎么解决
  详细解决方案

数据表,该怎么解决

热度:5522   发布时间:2013-02-26 00:00:00.0
数据表
现有一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
....

不知说清楚了没。谢谢您的任何宝贵的意见!
------解决方案--------------------------------------------------------
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;
  相关解决方案