为了实现varchar型的字段序号递增,我每次插入数据要先找出数据库中序号最大的那个再加1,可是对
varchar进行order by 时,得不到正确结果,如 varchar里,‘100’<'99'
怎么实现转化
另外,我只比较varchar的后几位,那个怎么截取后几位再进行int转化再排序呢?
回答1:
select * from yourtable order by cast(youcol as int)
回答2:
order by convert(int, 字段)
回答3:
但是你的列里面只能是数字组成的字符,要不然会出错
回答4:
create table #t(
b int identity(1,1),
a varchar(3)
)
insert into #t select '003'
insert into #t select '002'
insert into #t select '001'
insert into #t select '010'
insert into #t select '023'
--insert into #t select 'a03'
select * from #t order by cast(a as int)
drop table #t
回答5:
declare @maxid numeric(8)
select @maxid=max(isnull(cast(right(字段,x) as numeric),0)+1)
x表示从后面取多少位。 x表示从后面取多少位。 x表示从后面取多少位