日期:2014-05-19  浏览次数:20678 次

SQL语句Delete出现问题,请大家进来帮忙看看!
表名:item
字段   id   主键   标识
link       ntext

delete   item   where   id   not   in(select   max(id)   from   item   group   by   cast(link   as   varchar))
这是我原来的删除语句,想实现的效果是:删除link字段重复的数据,保留一条。

可是执行这句后会把一些link字段不重复的数据给删除。请大家帮忙看看是哪里错了,该怎么改才能实现我要的效果,谢谢!

------解决方案--------------------

--cast()如果不指定varchar的长度,默认只保留前30个字节

create table T (context text)

insert into T
select '啊0123456789-a-0123456789-b-0123456789-c-0123456789-d '

select context from T

select
cast(context as varchar) as 默认只保留30个字节,
len(cast(context as varchar)) as 字符个数,
datalength(cast(context as varchar)) as 字节数
from T

drop table T



------解决方案--------------------
--把你的SQL修改一下

delete item where id not in(select max(id) from item group by cast(link as varchar(8000)))