1. 程式人生 > >祝紫山(大可山人)部落格[GDI+,WPF, .Net圖形影象]

祝紫山(大可山人)部落格[GDI+,WPF, .Net圖形影象]

資料庫結構的指令碼:
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[TempA]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [dbo].[TempA]
GO

CREATE TABLE [dbo].[TempA] (
 [id] [int] IDENTITY (1, 1) NOT NULL ,
 [PositionName] [varchar] (256) COLLATE Chinese_PRC_CI_AS NULL ,
 [EnglishPositionName] [varchar] (256) COLLATE Chinese_PRC_CI_AS NULL
) ON [PRIMARY]
GO

ALTER TABLE [dbo].[TempA] ADD
 CONSTRAINT [PK_TempA] PRIMARY KEY  CLUSTERED
 (
  [id]
 )  ON [PRIMARY]
GO

TempA表中有三個欄位,id唯一且為主鍵,自動增長; PositionName,EnglishPositionName中有重複的記錄,比如:
id      PositionName        EnglishPositionName
20     其他                           Others
21     質量工程師               QC Engineer
22     其他                           Others
.......
100  質量工程師               QC Engineer
需要剔除重複的"其他","質量工程師"等記錄。

採用的SQL語句:
Delete from TempA where id not in (
        select max(t1.id) from TempA t1 group by
         t1.PositionName,t1.EnglishPositionName)

說明:
(1)需要剔除那幾個用於判斷重複的欄位,則將它們放在group by語句之後。
(2)max(t1.id) 也可以改成:min(t1.id)