永发信息网

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

答案:4  悬赏:10  手机版
解决时间 2021-03-15 21:01
  • 提问者网友:你独家记忆
  • 2021-03-15 12:58
oracle数据库表中,插入数据的时候如何产生一个 字母+数字 编号?
最佳答案
  • 五星知识达人网友:不如潦草
  • 2021-03-15 14:02
排序的话,用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
全部回答
  • 1楼网友:由着我着迷
  • 2021-03-15 16:56
建一个自增列id,像000001这样。那么SD||id就等于SD000001了
  • 2楼网友:渊鱼
  • 2021-03-15 16:25
create sequence 表名_seq increment by 1 start with 100000001 nocache;
insert into 表名(字段,字段,字段,字段)
values('SD'||表名_seq.nextval,'张三','123','Y');
这个东西又没什么逻辑的,不知道楼主究竟要怎样的效果追问嗯,说的有点道理,如何产生一个字母+日期+数字(数字是自增的) 例如: AC20120330001的代码呢?
  • 3楼网友:躲不过心动
  • 2021-03-15 14:50
先创建一个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')追答创建trigger时报错么?
重新编译下看看追问create trigger user_id_trg
before insert
on users
for each row
begin
:new.u_id:='SD'||lpad(seq_1.nextval,6,'0');
end;
嗯,执行上面代码后 trigger直接报错
错误在 seq_1.nextval 这里,这里不能放序列,
如果放一个 数字就没问题
是不是代码错了,我初次接触到触发器..
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯