读书人

查寻出重复的物料

发布时间: 2012-07-04 19:33:54 作者: rapoo

查找出重复的物料
编 码 名 称
3011003001 (Q40305)
3011003011 (Q40305彩锌)
3011003003 (Q403018)
3011003012 (Q403018红锌)
....... ......

根据上面数据显示名称这里有很多类似,比如(Q40305)和(Q40305彩锌)只多了彩锌两个字,如何删除名称为(Q40305)
保留(Q40305彩锌)?
谢谢!


[解决办法]

SQL code
--> 测试数据:[test]if object_id('[test]') is not null drop table [test]create table [test]([编码] varchar(12),[名称] varchar(11))goinsert [test]select '3011003001','Q40305' union allselect '3011003011','Q40305彩锌' union allselect '3011003003','Q403018' union allselect '3011003012','Q403018红锌'go--更正一下delete from test where PATINDEX('%[0-9]%',REVERSE([名称]))=1select * from test/*编码    名称---------------------------------3011003011    Q40305彩锌3011003012    Q403018红锌*/
[解决办法]
如果长度是固定的,可以尝试以下方法
SQL code
if object_id('[tb]') is not null drop table [tb]gocreate table [tb]([编码] bigint,[名称] varchar(13))insert [tb]select 3011003001,'(Q40305)' union allselect 3011003011,'(Q40305彩锌)' union allselect 3011003003,'(Q403018)' union allselect 3011003012,'(Q403018红锌)'godelete tbwhere exists(select 1 from tb a where left(tb.名称,7)=left(a.名称,7) and len(a.名称)>len(tb.名称))goselect * from tb/**编码                   名称-------------------- -------------3011003011           (Q40305彩锌)3011003012           (Q403018红锌)(2 行受影响)**/
[解决办法]
SQL code
--> 测试语句:DELETE t FROM [tb] AS tWHERE EXISTS    (    SELECT 1 FROM [tb]     WHERE REPLACE([名称],')','') LIKE REPLACE(t.[名称],')','')+'%'     AND REPLACE(t.[名称],')','') NOT LIKE REPLACE([名称],')','')+'%'    )SELECT * FROM [tb]/*编码                   名称-------------------- -------------3011003011           (Q40305彩锌)3011003012           (Q403018红锌)(2 行受影响)*/ 

读书人网 >SQL Server

热点推荐