位置: 编程技术 - 正文

在MySQL中创建实现自增的序列(Sequence)的教程(在mysql中创建数据库和表作业)

编辑:rootadmin

推荐整理分享在MySQL中创建实现自增的序列(Sequence)的教程(在mysql中创建数据库和表作业),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mysql语句创建,如何在mysql创建实例,实验训练1在mysql中创建数据库和表,mysql语句创建,mysql语句创建,如何在mysql创建实例,实验训练1在mysql中创建数据库和表,在mysql中创建数据表,内容如对您有帮助,希望把文章链接给更多的朋友!

项目应用中,曾有以下一个场景:接口中要求发送一个int类型的流水号,由于多线程模式,如果用时间戳,可能会有重复的情况(当然概率很小)。所以想到了利用一个独立的自增的sequence来解决该问题。当前数据库为:mysql由于mysql和oracle不太一样,不支持直接的sequence,所以需要创建一张table来模拟sequence的功能,理由sql语句如下:第一步:创建--Sequence 管理表

第二步:创建--取当前值的函数

第三步:创建--取下一个值的函数

第四步:创建--更新当前值的函数

第五步:测试函数功能当上述四步完成后,可以用以下数据设置需要创建的sequence名称以及设置初始值和获取当前值和下一个值。

INSERT INTO sequence VALUES ('TestSeq', 0, 1);----添加一个sequence名称和初始值,以及自增幅度 SELECT SETVAL('TestSeq', );---设置指定sequence的初始值 SELECT CURRVAL('TestSeq');--查询指定sequence的当前值 SELECT NEXTVAL('TestSeq');--查询指定sequence的下一个值

在java代码中,可直接创建sql语句查询下一个值,这样就解决了流水号唯一的问题。贴出部分代码(已测试通过)

ps:在应用中,还有一种用java代码去实现模拟自增sequence的方式,具体思路是创建一张存放sequence的table,然后通过java调用sql语句去查询和修改这个table中指定sequence名称的值,这种方式请加上synchronized。具体代码这里就不上传了,因为实现了,未去测试过。

在MySQL中创建实现自增的序列(Sequence)的教程(在mysql中创建数据库和表作业)

在 oracle 中, sequence 提供多表多字段可共用一个不重复值。 Mysql 中存在自增列,基本可以满足 PK 的要求。但自增列存在限制:

a. 只能用于表中的一个字段,一张不能同时存在两个以上的自增列 ;

b. 自增列必须被定义为 key ( PK 或 FK ) ;

c. 自增列不能被多个表共用 ;

d. 当 insert 语句不包括自增字段或将其值设置为 NULL 时,该值会自动填上。

在不要求字段顺序递增的情况下,可以在 Mysql 中实现序列,再来看下面一个例子:

在 SQL 中使用序列:创建序列,往sequence表插入值即可:

查看当前已建序列:

获得序列的下一个值,第一次使用,因此值为1:

MySQL存储过程中一些基本的异常处理教程 有时候,不希望存储过程抛出错误中止执行,而是希望返回一个错误码。Mysql支持异常处理,通过定义CONTINUE/EXIT异常处理的HANDLER来捕获SQLWARNING/NOTFOUND/SQ

MySQL性能监控软件Nagios的安装及配置教程 Nagios是一款Linux上成熟的监视系统运行状态和网络信息的开原IT基础设施监视系统,Nagios能监视所指定的本地或远程主机及服务,例如HTTP服务、FTP服务等

安装配置MySQLMTOP来监控MySQL运行性能的教程 一、环境说明1、服务器角色2、系统环境CentOS6.2x_、环境要求(1)、MySQL5.0及以上(用来存储监控系统采集的数据)(2)、Apache2.2及以上(WEB服务器运行服

标签: 在mysql中创建数据库和表作业

本文链接地址:https://www.jiuchutong.com/biancheng/312414.html 转载请保留说明!

上一篇:MySQL中临时表的基本创建与使用教程(mysql临时表什么时候销毁)

下一篇:MySQL存储过程中一些基本的异常处理教程(mysql存储过程之错误处理)

  • 动态市盈率与静态市盈率区别百度百科
  • 实收资本印花税最新规定
  • 外地预缴所得税的会计分录
  • 印花税会计分录怎么做
  • 研发支出管理制度
  • 采购成本和销售费用区别
  • 百旺税控盘自己用不了
  • 城建税减免性质代码 0申报
  • 建筑企业异地申报个税
  • 收据能入账抵税吗
  • 养老院营利性与非营利如何认定
  • 委托加工物资需要计提存货跌价准备吗
  • 坏账准备的账务处理4步
  • 企业购买电话充值卡的分录
  • 个人所得税差额20%政策
  • 企业年度财务报表主要包括
  • 收客户款现金折让发票怎么处理
  • 离境退税政策文件
  • 资本公积与什么有关
  • 一般纳税人转登记为小规模纳税人
  • 金税三期社保费管理客户端v1.0.088(生产环境)
  • 发票未到货已到怎么入账
  • 会计账簿的定义及其作用
  • 保险营销员的佣金怎么算个税
  • 小规模企业营业税
  • 工会发放员工福利的通知
  • 代缴公司不给停社保怎么办
  • 进口商品买卖的关键环节
  • 建筑业简易征收进项税额转出
  • 收到境外公司服务费
  • 酒店住宿收入确认原则的条件
  • 购买厂房可以一次买卖吗
  • 员工垫付货款走报销吗
  • 收取赔偿金开具什么发票
  • 企业所得税以前年度所得调整
  • 工资五险一金缴费标准是多少
  • 现在还有短期投资这个科目吗
  • 专用发票可以抵税是什么意思
  • 解放双手神器说说
  • 应收票据到期收回时和未到期转让时
  • 退休返聘工资如何申报个人所得税
  • 一般纳税人销售自己使用过的汽车
  • 购进土地会计分录
  • 销售使用过的汽车会计分录
  • win7纯净版系统之家
  • 前端生成pdf文件
  • elementui中的el-tab-pane为什么内容会为0
  • win7界面旋转
  • 消防工程款支付方式
  • 挂靠的项目怎么做账
  • 波尔图葡萄牙语
  • vue和react差别
  • qt无边框窗口设计
  • 金税盘抵免增值税怎么做账
  • 劳务派遣差额征税的账务处理实例
  • 织梦怎么建站
  • 政府补助 项目资本金
  • 海关完税凭证抵税怎么算
  • 新会计准则哪一年颁布
  • 一般纳税人应交增值税
  • c#连接access数据库实例
  • 自产产品对外捐赠要确认收入吗
  • 运费与快递费的区别在哪
  • 怎样计提税金及附加
  • 固定资产报废怎么开票
  • 出口未报关收到外汇怎样处理
  • 关于外贸企业出口的规定
  • 积分中的换元怎么使用
  • mysql 5.7.34安装
  • 找回被删除的文件时第一步应该是什么
  • solaris挂载nfs
  • windows server 2008 r2激活密钥
  • f11一键恢复系统详解
  • win10系统电脑关机自动重启
  • 基于stm32的100个毕业设计
  • 基于javascript数独游戏论文参考文献
  • python中按下某个按键
  • javascriptcsdn
  • 咨询服务类公司的账务处理
  • 智能财税证书含金量多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设