在填报表中如何正确使用自动增长的字段
来源:互联网 发布:网络用语菜鸟什么意思 编辑:程序博客网 时间:2024/05/16 04:39
在多用户并发进行填报的时候,总会遇到一个发生率很高的问题,就是主键的重复。主键重复造成的结果是前一个用户的填报内容,被另一个用户给覆盖掉了,造成了数据丢失。
这个问题如果由编程人员来解决,那将会是一件非常麻烦的事情。但是如果交由数据库去处理,就变得简单多了,因为不管多少个用户,对数据库来说只是一个更新数据库的命令队列,数据库本身会对主键的问题进行判断。这也就是大多数数据库提供的字段自动增长功能的原因。
而我们的报表系统里面也支持了这种自动增长字段的方式,如下图:
由此可见,在报表端设置起来是非常简单的。
下面介绍一下针对三种常用的数据库,自动增长字段的设置方法:
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');
可以看到,在未指定主键值的情况下,数据库会自动帮我们生成主键,保证了数据的唯一性。
- 在填报表中如何正确使用自动增长的字段
- 如何在填报表中使用自定义的下拉日历
- 如何在oracle中设置字段自动增长
- 如何在oracle中设置字段自动增长
- 如何在oracle中设置字段自动增长
- 如何在oracle中设置字段自动增长
- 如何在oracle数据库中设置自动增长的id字段
- 在oracle中创建自动增长字段
- 在oracle中创建自动增长字段
- 在oracle中创建自动增长字段
- 如何在ADF中使用Sequence自动增长
- 数据库中自动增长的字段类型
- SQL Server自动增长字段的使用
- SQL Server自动增长字段的使用
- 在Oracle中使用自增长字段
- 报表填报时新增一行序号自动增长
- 如何实现填报表不同单元格的自动关联填充
- db2中字段自动增长
- 动态链接库加载原理及HotFix方案介绍
- Linux 设备驱动之字符设备(二)
- 人工智能各种技术与算法
- 第十三周 【项目五 验证拓扑排序】
- Linux下编译安装apache
- 在填报表中如何正确使用自动增长的字段
- LeetCode:382 Linked List Random Node蓄水池抽样算法
- 怎么修改input中placeholder的字体颜色
- Android中SQLite数据库使用
- 润乾报表在OC4J服务器下的部署方法
- Android之RecyclerView
- mysql批量select插入
- java 用poi 将远程共享文件夹中word转html
- EventBus3.0.0的使用