sql中,把varchar类型转换成int型,在进行排序
2010-12-11 10:49
351 查看
为了实现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表示从后面取多少位。
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表示从后面取多少位。
相关文章推荐
- sql中把varchar类型转换为int型然后进行排序
- sql中把varchar类型转换为int型然后进行排序
- sql中,把varchar类型转换为int型,然后进行排序
- sql中,把varchar类型转换为int型,然后进行排序
- sql中,把varchar类型转换为int型,然后进行排序
- sqlserver中将varchar类型转换为int型再进行排序的方法
- SQLServer 中把varchar类型转换为int型然后进行排序
- sqlserver中将varchar类型转换为int型再进行排序的方法
- sqlserver中将varchar类型转换为int型再进行排序的方法
- sqlserver中将varchar类型转换为int型再进行排序的方法
- 在sql中将varchar型转换成int型再进行排序
- sql将varchar类型转换为Int类型排序
- sqlserver中将varchar类型转换为int型
- uniqueidentifier转换成varchar数据类型的sql语句
- sql uniqueidentifier转换成varchar 数据类型
- MySql中的varchar转换成int类型排序
- linq to sql 查询后排序(字符串类型的数字进行排序)
- mysql中字符和数字在执行sql时进行类型转换
- sql使用cast进行数据类型转换示例
- SQL根据字符串类型字段进行排序,可以在取值的时候处理