[url=http://hi.baidu.com/ijunxiong/blog/item/3568f04a9ad218f782025c91.html]原文链接[/url]
为了实现varchar型的字段序号递增,我每次插入数据要先找出数据库中序号最大的那个再加1,可是对
varchar进行order by 时,得不到正确结果,如 varchar里,‘100’<'99'
怎么实现转化
另外,我只比较varchar的后几位,那个怎么截取后几位再进行int转化再排序呢?
[b]回答1:[/b]
select * from yourtable order by cast(youcol as int)
[b]回答2:[/b]
order by convert(int, 字段)
[b]回答3:[/b]
但是你的列里面只能是数字组成的字符,要不然会出错
[b]回答4:[/b]
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
[b]回答5:[/b]
declare @maxid numeric(8)
select @maxid=max(isnull(cast(right(字段,x) as numeric),0)+1)
x表示从后面取多少位。 x表示从后面取多少位。 x表示从后面取多少位。
为了实现varchar型的字段序号递增,我每次插入数据要先找出数据库中序号最大的那个再加1,可是对
varchar进行order by 时,得不到正确结果,如 varchar里,‘100’<'99'
怎么实现转化
另外,我只比较varchar的后几位,那个怎么截取后几位再进行int转化再排序呢?
[b]回答1:[/b]
select * from yourtable order by cast(youcol as int)
[b]回答2:[/b]
order by convert(int, 字段)
[b]回答3:[/b]
但是你的列里面只能是数字组成的字符,要不然会出错
[b]回答4:[/b]
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
[b]回答5:[/b]
declare @maxid numeric(8)
select @maxid=max(isnull(cast(right(字段,x) as numeric),0)+1)
x表示从后面取多少位。 x表示从后面取多少位。 x表示从后面取多少位。