Oracle 语句中“||”代表什么啊?
oracle数据库表中,插入数据的时候如何产生一个 字母+数字 编号?
排序的话,用order by来处理即可。比如:cola123a234b999b335select * from tablename order by col; 结果就是 cola123a234b335b999 如果按倒序排列:select * from tablename order by col desc; 结果就是 colb999b335a234a123
其他回答
先创建一个sequence
然后给插入数据的表写个trigger;before insert 的时候 设置这个字段的值为
SD||sequence.nextval
追问
不是很明白,不知道这位大哥,能否贴出一个例子...
追答
create sequence seq_1 start with 1 nocache;seq_1为序列名称触发器如下: create trigger xxx_id_trg --trigger namebefore inserton 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_1create trigger user_id_trgbefore inserton 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
举报| 评论
=================
2 0
create sequence 表名_seq increment by 1 start with 100000001 nocache;
insert into 表名(字段,字段,字段,字段)
values(‘SD‘||表名_seq.nextval,‘张三‘,‘123‘,‘Y‘);
这个东西又没什么逻辑的,不知道楼主究竟要怎样的效果
追问
嗯,说的有点道理,如何产生一个字母+日期+数字(数字是自增的) 例如: AC20120330001的代码呢?
patooo | 发布于2012-03-27
举报| 评论
=============
2 0
建一个自增列id,像000001这样。那么SD||id就等于SD000001了
原文地址:https://www.cnblogs.com/hfultrastrong/p/8278383.html
时间: 2024-10-13 22:53:14