zoukankan      html  css  js  c++  java
  • 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了
  • 相关阅读:
    find文件后cp、rm
    值得加分的
    对老师的评价
    关于Statement 与 PreparedStatement
    每日日报2021.1.14
    每日日报2020.1.12
    每日日报2021.1.11
    给自己算的加分项
    期末了,给老师提建议。
    每日日报2020 12/19
  • 原文地址:https://www.cnblogs.com/hfultrastrong/p/8278383.html
Copyright © 2011-2022 走看看