• [转]润乾报表实现主键自增长


    原文地址:http://blog.csdn.net/alice_656/article/details/53585030

    在多用户并发进行填报的时候,总会遇到一个发生率很高的问题,就是主键的重复。主键重复造成的结果是前一个用户的填报内容,被另一个用户给覆盖掉了,造成了数据丢失。这个问题如果由编程人员来解决,那将会是一件非常麻烦的事情。但是如果交由数据库去处理,就变得简单多了,因为不管多少个用户,对数据库来说只是一个更新数据库的命令队列,数据库本身会对主键的问题进行判断。这也就是大多数数据库提供的字段自动增长功能的原因。

    而我们的报表系统里面也支持了这种自动增长字段的方式,如下图:

     

    由此可见,在报表端设置起来是非常简单的。

    下面介绍一下针对三种常用的数据库,自动增长字段的设置方法:

    1、MySQL
    在建表的时候,在主键字段后面加上AUTO_INCREMENT即可,例如:
    CREATE TABLE AUTO_KEY_TABLE (
    ID INT PRIMARY KEY AUTO_INCREMENT,
    DATA VARCHAR(255)
    );

    2、SQLServer
    SQLServer相对麻烦一些,需要在企业管理器里面配置,如下图:

     

    3、Oracle
    这个是最麻烦的,因为Oracle提供的自动增长方式与前两个不同。在Oracle里面提供了序列对象,由该序列提供一个唯一值,但是我们每次插入数据的时候,需要在SQL中调用这个序列才可以。
    但是Oracle也同时提供了触发器的功能,可以在插入数据前自动调用触发器,从而实现我们的目的。完整的代码如下:
    -- 创建演示表
    CREATE TABLE AUTO_KEY_TABLE("ID" INT PRIMARY KEY,"DATA" VARCHAR(255));
    -- 创建一个序列
    CREATE SEQUENCE AUTO_KEY_SEQ;
    -- 创建触发器
    CREATE TRIGGER BIFER_AUTO_KEY_TABLE
    BEFORE INSERT ON AUTO_KEY_TABLE
    REFERENCING
    OLD AS OLD_VALUE
    NEW AS NEW_VALUE
    FOR EACH ROW
    BEGIN
      SELECT AUTO_KEY_SEQ.NEXTVAL INTO :NEW_VALUE.ID FROM DUAL;
    END;

    上面的操作完成后,我们可以通过以下SQL测试一下:
    INSERT INTO AUTO_KEY_TABLE(DATA) VALUES('test');
    可以看到,在未指定主键值的情况下,数据库会自动帮我们生成主键,保证了数据的唯一性。

  • 相关阅读:
    centos中安装docker
    docker es
    Linux 定时备份数据库
    Linux 防火墙firewalld
    Linux Systemd
    Linux at定时任务
    Linux运行级别
    原来这就是网络
    LeetCode-897-递增顺序搜索树
    SSM整合配置文件
  • 原文地址:https://www.cnblogs.com/dirgo/p/7826918.html
Copyright © 2020-2023  润新知