sql中,把varchar类型转换成int型,在进行排序

[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表示从后面取多少位。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值