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)))