oracle,如何添加排序编号字段
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle,如何添加排序编号字段相关的知识,希望对你有一定的参考价值。
参考技术A 直接加非空字段肯定不行,你先加个空字段,更新值,再改属性为非空alter
table
tablename
add
id
number;
update
tablename
set
id=rownum;
--这里不知道你要按什么顺序
alter
table
tablename
modify
id
not
null; 参考技术B 直接order
by
pro_d
是按字符串排序的,不能得到按数字大小的排序效果;
应该去掉前边的字符然后再排序:
order
by
to_number(substr(pro_d,
4)) 参考技术C 楼上的方法好麻烦
这样
select row_number() over(order by 排序字段) rn,表名.* from 表名
oracle数据库表中,插入数据的时候如何产生一个 字母+数字 编号?
Oracle 语句中“||”代表什么啊?
oracle数据库表中,插入数据的时候如何产生一个 字母+数字 编号?
排序的话,用order by来处理即可。
比如:
col
a123
a234
b999
b335
select * from tablename order by col;
结果就是
col
a123
a234
b335
b999
如果按倒序排列:
select * from tablename order by col desc;
结果就是
col
b999
b335
a234
a123
其他回答
先创建一个sequence
然后给插入数据的表写个trigger;before insert 的时候 设置这个字段的值为
SD||sequence.nextval
然后给插入数据的表写个trigger;before insert 的时候 设置这个字段的值为
SD||sequence.nextval
追问
不是很明白,不知道这位大哥,能否贴出一个例子...
追答
create sequence seq_1 start with 1 nocache;
seq_1为序列名称
触发器如下:
create trigger xxx_id_trg --trigger name
before insert
on table_name
for each row
begin
:new.column_name:=SD||lpad( seq_1.nextval,6,\'0\');
end;
追问
--users 是表名,包括两个字段, u_id 和 u_name
--seq_1 是序列名
--u_id 是列名,也就是要生成编号的列,类型为varchar2型
--序列已经创建,名字为 seq_1
create trigger user_id_trg
before insert
on users
for each row
begin
:new.u_id:=SD||lpad(seq_1.nextval,6,\'0\');
end;
--执行插入的时候报错,触发器无效
insert into users(u_name) values(\'a\')
本回答被提问者采纳
建一个自增列id,像000001这样。那么SD||id就等于SD000001了
以上是关于oracle,如何添加排序编号字段的主要内容,如果未能解决你的问题,请参考以下文章