Foxnic-SQL (10) —— DAO 特性 : 生成序列

LeeFJ
• 阅读 379

Foxnic-SQL (10) —— DAO 特性 : 生成序列

概述

  在数据库层面,各个数据库对序列的支持是不一样的。大多数数据库可以为表指定一个自增的字段,但这种自增字段却很不利于数据的迁移。类似 Oracle 的数据库有专门的序列对象,但这种方式太独特,也不利于在产品层面的多数据库适配。基于这样的考虑,Foxnic-SQL 单独实现了基于存储过程的序列。
  本文中的示例代码均可在 https://gitee.com/LeeFJ/foxnic-samples 项目中找到。

手动定义序列

  获取序列的定义可以有两种方式:界面配置和程序配置。界面配置在系统管理->系统配置-> 序列管理进行配置,如图所示:
Foxnic-SQL (10) —— DAO 特性 : 生成序列
  其中,序列的 key 一旦指定,不再可随意修改,再编程取数时会用到这个 key 值。长度是指序列值字符数,如果不足则补0,如果数值过大,则溢出,长度值加1。取值个数是指每次向数据库请求的序列值的个数,由于请求序列值都需要向数据库请求,这样就会有额外的开销,为了减少开销,可以一次请求取回多个值,以获得更好的并发性能。

程序定义序列

  程序定义序列是指通过程序的方式创建序列,如下代码所示:

// 创建DAO
DAO dao=DBInstance.DEFAULT.dao();
String name="my-sample-demo";
DBSequence sequence=dao.getSequence(name);
// 如果不存在就创建
if(!sequence.exists()) {
    // 创建序列
    sequence.create(SequenceType.AI,10,4);
}

  上面的例子中,首先使用 DAO 得到序列对象,接着判断是否已经存在,如果不存在就创建。

序列取数

  序列取数时可以获得 Long 类型的值和字符串类型的值,字符串值当长度不足时自动不0。序列取数使用 DBSequence 类的 nextLong() 方法或 next() 方法。以下是完整的示例代码:

public static void main(String[] args) {
    // 创建DAO
    DAO dao=DBInstance.DEFAULT.dao();
    String name="my-sample-demo";
    DBSequence sequence=dao.getSequence(name);
    // 如果不存在就创建
    if(!sequence.exists()) {
        // 创建序列
        sequence.create(SequenceType.AI,10,4);
    }
    // 循环取数
    for (int i = 0; i < 100; i++) {
        // 获取 Long 值
        System.out.println(i+" = "+sequence.nextLong());
        // 获得 String 值
        System.out.println(i+" = "+sequence.next());
    }
}

小结

  本节主要介绍了在 Foxni-SQL 中两种序列的创建方式,分别是手工创建和程序创建,以及如何通过 DBSequence 取得下一个序列值。

相关项目

  https://gitee.com/LeeFJ/foxnic
  https://gitee.com/LeeFJ/foxnic-web
  https://gitee.com/lank/eam
  https://gitee.com/LeeFJ/foxnic-samples

官方文档

  http://foxnicweb.com/docs/doc.html

点赞
收藏
评论区
推荐文章
Stella981 Stella981
3年前
Hive中使用row_number() over()创建自增主键
虽然hive中的表没有主键一说,但是实际数据开发中经常需要将hive中计算好的表导出到mysql库中供业务使用或开发调用,而mysql表是需要有主键的,在hive中我们可以使用row\_number()over()窗口函数来生成一个自增序列的字段,在将表导出到mysql库中的时候就可以指定该字段为主键,使用起来还是挺方便的。select
Wesley13 Wesley13
3年前
oracle中如何创建表的自增ID(通过序列)
1、什么是序列呢?   序列是一数据库对象,利用它可生成唯一的整数。一般使用序列自动地生成主码值。一个序列的值是由特别的Oracle程序自动生成,因而序列避免了在运用层实现序列而引起的性能瓶颈。Oracle序列允许同时生成多个序列号,而每一个序列号是唯一的。当一个序列号生成时,序列是递增,独立于事务的提交或回滚。容许设计缺省序列,不需指定任何子句
Wesley13 Wesley13
3年前
MySQL 序列使用:使用 AUTO_INCREMENT、获取AUTO_INCREMENT值
MySQL序列使用MySQL序列是一组整数:1,2,3,...,由于一张数据表只能有一个字段自增主键,如果你想实现其他字段也实现自动增加,就可以使用MySQL序列来实现。本章我们将介绍如何使用MySQL的序列。使用AUTO\_INCREMENTMySQL
Wesley13 Wesley13
3年前
mysql关于自动编号问题 转载
MySql数据库唯一编号字段(自动编号字段)在数据库应用,我们经常要用到唯一编号,以标识记录。在MySQL中可通过数据列的AUTO\_INCREMENT属性来自动生成。MySQL支持多种数据表,每种数据表的自增属性都有差异,这里将介绍各种数据表里的数据列自增属性。ISAM表如果把一个NULL插入到一个AUTO\_INCREMEN
Stella981 Stella981
3年前
Linux 下连接sqlserver(下)
基于ODBC开发odbc接口环境部署好后,就可以开始进行开发了,微软官网有详细的接口操作说明,但odbc接口还是太底层,操作起来比较麻烦,这里采用数据库的封装类soci来实现快速开发。soci是一个用C封装的数据库访问库,通过“前端(应用程序)/核心/后端(数据库适配)”模式支持firebird,mysql,sql
Wesley13 Wesley13
3年前
Java序列化——transient关键字和Externalizable接口
  提到Java序列化,相信大家都不陌生。我们在序列化的时候,需要将被序列化的类实现Serializable接口,这样的类在序列化时,会默认将所有的字段都序列化。那么当我们在序列化Java对象时,如果不希望对象中某些字段被序列化(如密码字段),怎么实现呢?看一个例子:import java.io.Serializable;imp
Wesley13 Wesley13
3年前
ORACLE 12C Identity Column(身份列) 实现自增长字段
Oracle12c提供的IdentityColumn特性简化了自增字段的定义。声明自增字段通常有3种常见的用法,以下三种方式都支持INSERT语句中省略自增字段的插入,但有些许差别。1\.GENERATED\ALWAYS\ASIDENTITY此时ALW
Vitess全局唯一ID生成的实现方案 | 京东云技术团队
为了标识一段数据,通常我们会为其指定一个唯一id,比如利用MySQL数据库中的自增主键。但是当数据量非常大时,仅靠数据库的自增主键是远远不够的,并且对于分布式数据库只依赖MySQL的自增id无法满足全局唯一的需求。因此,产生了多种解决方案,如UUID,Sn
燕青 燕青
1年前
Mac序列号查询工具:KCNScrew
KCNScrew是一款序列号查询工具,它专门为MAC用户设计,是一款十分简单好用的序列号查找工具。KCNScrewPackformac内置强大的序列号数据库,包含数千款Mac软件序列号,大多数常用软件的序列号都可以在KCNScrewPackformac中找