oracle中如何加字母,Oracle数据库之oracle数据库表插入数据的时候如何产生一个字母+数字...

本文主要向大家介绍了Oracle数据库之oracle数据库表插入数据的时候如何产生一个字母+数字,通过具体的内容向大家展现,希望对大家学习Oracle数据库有所帮助。

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了

本文由职坐标整理并发布,希望对同学们学习Oracle有所帮助,更多内容请关注职坐标数据库Oracle数据库频道!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值