位置: 编程技术 - 正文

在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存储过程之错误处理)

  • 清税证明是什么要钱吗
  • 分公司可以享受当地优惠吗?
  • 私对公转账可以撤回吗
  • 预付费卡税务处理
  • 营改增一般纳税人标准
  • 投资损失怎么进行季度所得税申报
  • 房地产对居民生活的影响
  • 公司付给职工的工资
  • 天然气的销售需要什么资质
  • 用友t3财务报表模块打不开
  • 利息发票能开专票吗
  • 社保稳岗补贴可以申请几次
  • 现金存入对公账户用途写什么
  • 跨年度多计提的社保调整
  • 资产总额小于所有者权益合计
  • 跨期发票如何进行会计处理?
  • 办公室装修计入什么科目里
  • 开机默认开启数字键
  • 开具成品油发票规格型号有哪些要求
  • 固定资产减值准备影响折旧吗
  • 红蘑菇是什么松树伞吗
  • phpexplode函数
  • 呆滞品报废入什么科目
  • 押金少退侵犯了哪条法律
  • 路由器和交换机用什么线连接
  • 转售股票会计分录
  • php读取目录
  • 收益类账户借增贷减
  • 运输合同印花税税率
  • 无偿转让房屋
  • 发票多开了 财务怎么算税点
  • ChatGPT遭禁用、抵制后又停止Plus付费发生了?
  • which 查找文件
  • discuz去除底部
  • 增值税普通发票和专用发票有什么区别
  • 子公司如何向母公司申请用印
  • 去年未分配利润为负什么意思
  • 没有实收资本的股权原值
  • 以前年度进项转出账务处理
  • 预缴税款可以抵扣简易计税
  • 更正申报失败,维持原申报?
  • sql server触发器的作用
  • 季报现金流量表可以不填吗
  • 微信支付宝等第三方支付的优缺点
  • 年终奖可以税前扣除吗
  • 公司销售的产品算固定资产吗
  • 企业选择简易征收方案
  • 政府补助的界定
  • 材料发票税额
  • 公司组织出国旅游很差吗
  • 单位收风险金是什么意思
  • 递延所得税资产和递延所得税负债
  • 当月作废的专票还是要交增值税吗
  • 本年利润的借方科目
  • 小企业会计准则主要按照什么计量
  • sql参数化是什么意思
  • win10小娜如何使用
  • win10系统设置快捷键
  • 修改远程桌面端口后,远程桌面连不上
  • kali linux 视频教程
  • Windows正在启动卡死
  • win7j
  • 如何删除双系统中的linux系统
  • win10预览文件怎么显示内容
  • onetouch.exe - onetouch是什么进程 有什么用
  • 深入了解linux内核
  • android环境搭建教程
  • python中map函数功能
  • python把html页面生成图片
  • 单向链表的基本操作
  • 编写js代码要注意什么
  • js == ===区别
  • android遇到的难题,怎么解决的
  • 税务电子发票怎么开
  • 文化事业建设费是什么税
  • 陕西税务管网
  • 国家税务局申请电子发票怎么申请
  • 附加税申报表样本
  • 预测收入遵循什么方法
  • 济南税务局,济南电子税务局官网
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设