oracle数据库表中,插入数据的时候如何产生一个 字母+数字 编号?

Posted Archibald Witwicky

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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
 
追问
不是很明白,不知道这位大哥,能否贴出一个例子...
 
追答
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\')
 本回答被提问者采纳
moreazy  发布于2012-03-22
举报| 评论 
 
=================
 
0
create sequence 表名_seq increment by 1 start with 100000001 nocache;

insert into 表名(字段,字段,字段,字段)
values(\'SD\'||表名_seq.nextval,\'张三\',\'123\',\'Y\');

这个东西又没什么逻辑的,不知道楼主究竟要怎样的效果
 
追问
嗯,说的有点道理,如何产生一个字母+日期+数字(数字是自增的) 例如:  AC20120330001的代码呢?
patooo  发布于2012-03-27
举报| 评论 
 
=============
 
0
建一个自增列id,像000001这样。那么SD||id就等于SD000001了

以上是关于oracle数据库表中,插入数据的时候如何产生一个 字母+数字 编号?的主要内容,如果未能解决你的问题,请参考以下文章

Oracle中插入数据

如何使用oracle程序将数据从多个表中插入一个表中

如何向Oracle数据库表中进行大数据量的插入并提交?

我是一个初学者,如何向oracle数据库表中插入数据

如何使用oracle中的触发器从另外两个表中插入一个表中的数据

oracle/sql中如何根据条件向表中插入数据