- 1、本文档共7页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
mysql锁解决并发问题.pdf
mysql 锁解决并发问题
文章分为以下几个要点
1. 问题描述以及解决过程
2. MySQL 锁机制
3. 数据库加锁分析
下面讨论的都是基于 MySQL 的 InnoDB。
0. 问题描述以及解决过程
因为涉及到公司利益问题,所以下面很多代码和数据库信息,进行了缩减和修改,望见谅。
业务场景是优惠券系统规则规定了一个优惠券活动最多可发行多少张优惠券和每个用户最多可领取优惠券数量。
下面列出两张表的结构。
活动表
CREATE TABLE `coupon_activity` (
`act_id` int(11) NOT NULL AUTO_INCREMENT COMMENT 主键,
`act_code` char(6) NOT NULL DEFAULT COMMENT 活动编码,
`coup_issue_num` int(11) NOT NULL DEFAULT 0 COMMENT 优惠券发行量,
`coup_per_num` int(11) NOT NULL DEFAULT 0 COMMENT 单个用户可领取数,
PRIMARY KEY (`act_id`),
UNIQUE KEY `act_code_idx` (`act_code`) COMMENT 活动编码唯一索引
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
优惠券明细表
CREATE TABLE `coupon_detail` (
`coup_id` int(11) NOT NULL AUTO_INCREMENT,
`act_code` char(6) NOT NULL DEFAULT COMMENT 活动编号,
`coup_code` char(6) NOT NULL DEFAULT COMMENT 优惠券编码,
`coup_user_id` int(11) NOT NULL DEFAULT 0 COMMENT 领取券用户 id,
PRIMARY KEY (`coup_id`),
UNIQUE KEY `coup_code_idx` (`coup_code`) USING BTREE COMMENT 优惠券编码唯一索引,
KEY `coup_user_idx` (`coup_user_id`) USING BTREE COMMENT 用户 id 普通索引,
KEY `act_code_idx` (`act_code`) USING BTREE COMMENT 活动编码普通索引
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT=优惠券明细表;
假设一个优惠券活动设置的最大发行量为 1000 张优惠券,单个用户最多可领取 1 张优惠券。如下
insert into coupon_activity values (1,000000,1000,1,0);
1 / 7
不考虑到并发的话,用户 10 领取 act_code=’000000’活动的优惠券 执行的 sql 如下。注意#{}里面的字段表示之前的 sql
查询出来的字段。
begin;
select * from coupon_activity where act_code = 000000;
select count(coup_id) as count_all from coupon_detail where act_code = #{act_code};
select count(coup_id) as count_per from coupon_detail where coup_user_id = 10 and act_code = #{act_cod
e};
//插入明细表 首先判断是否当前领用量小于活动发行量,当前用户领取量是否小于每个用户可领取数
if(#{count_all} #{coup_issue_num} #{count_per} #{coup_per_num}){
您可能关注的文档
- 4单相多相合金的凝固.ppt
- 4月6日金葵花投资...pdf
- 4种裸子植物内生真菌抗肿瘤菌株的筛选.pdf
- 9Cr2Mo钢中贝氏体的组织形貌.pdf
- ADINA 时间步和时间函数.pdf
- Al-0.53Zn合金近快速定向凝固条件下的胞晶间距选择.pdf
- Al-Pb合金的快速定向凝固及其模拟.pdf
- android_ROM分解定制签名教程.pdf
- AZ31镁合金单晶初始屈服行为的数值模拟2.pdf
- BC52A RDPL-c30初始产品说明书20150108.pdf
- 2023-2024学年黑龙江省哈尔滨市中考数学试卷(附答案解析).docx
- 中考语文抢分秘籍专题07九年级上册重点古诗词必背知识点.docx
- 中考语文满分作文热点素材集锦及实战演练专题03 后疫情时代:写作角度+关键词+金句名言+时评+范文.docx
- 中考语文抢分秘籍秘籍06古诗文名篇名句默写(原卷版+解析).docx
- 中考语文抢分秘籍专题17中考字音、字形分册梳理.docx
- 2023-2024学年山东省济宁市中考数学试卷(附答案解析).docx
- 中考语文满分作文热点素材集锦及实战演练专题06 汶川地震被救少年14年后救火牺牲.docx
- 中考语文满分作文热点素材集锦及实战演练专题03 天宫课堂第三课.docx
- 中考语文满分作文热点素材集锦及实战演练专题04 《典籍里的中国》“大而美”古籍因此“活起来”.docx
- 2023-2024学年山东省济南市中考数学试卷(附答案解析).docx
最近下载
- SY_T 5660-2020 钻井液用包被絮凝剂 聚丙烯酰胺类.pdf VIP
- 2021-202x年基金管理人员工跟投基金投资协议-经典(律师审定版).docx
- 2010-2015年 中国电梯行业市场发展前景及投资分析报告.doc
- 78度智慧参考资料.pdf
- 基层儿科医务人员服务能力提升学习班答案-2024华医网继续教育答案.docx VIP
- DELTA台达伺服驱动器 ASDA-A2使用手册-操作说明书.pdf
- 国际贸易实务英文版(第五版)周瑞琪教材辅导习题解答.pdf
- 基于高斯滤波和近似积分的电动车窗防夹算法.pdf
- Application for Export Transaction 离岸客户填写指南.doc VIP
- 2023年膨化食品行业市场需求分析报告及未来五至十年行业预测报告.docx
文档评论(0)