当前位置: 首页 > news >正文

php做网站安性如何福州网站建设电话

php做网站安性如何,福州网站建设电话,临沂医院网站建设,上海原画培训机构排名以下的文章主要向大家描述的是MySQL数据库和相关事务#xff0c;在实际操作中有很多人都认为MySQL数据库对事务处理是不支持的#xff0c;其实#xff0c;只要MySQL数据库版本支持BDB或是InnoDB表类型#xff0c;那么你的MySQL就具有事务处理的能力。这里面#xff0c;又以…以下的文章主要向大家描述的是MySQL数据库和相关事务在实际操作中有很多人都认为MySQL数据库对事务处理是不支持的其实只要MySQL数据库版本支持BDB或是InnoDB表类型那么你的MySQL就具有事务处理的能力。这里面又以InnoDB表类型用的最多虽然后来发生了诸如Oracle收购InnoDB等令MySQL不爽的事情但那些商业上的斗争与技术无关下面以InnoDB表类型为例简单说一下MySQL中的事务。先来明确一下事务涉及的相关知识事务都应该具备ACID特征。所谓ACID是Atomic(原子性)Consistent(一致性)Isolated(隔离性)Durable(持续性)四个词的首字母所写下面以“银行转帐”为例来分别说明一下它们的含义原子性组成事务处理的语句形成了一个逻辑单元不能只执行其中的一部分。换句话说事务是不可分割的最小单元。比如银行转帐过程中必须同时从一个帐户减去转帐金额并加到另一个帐户中只改变一个帐户是不合理的。一致性在事务处理执行前后MySQL数据库是一致的。也就是说事务应该正确的转换系统状态。比如银行转帐过程中要么转帐金额从一个帐户转入另一个帐户要么两个帐户都不变没有其他的情况。隔离性一个事务处理对另一个事务处理没有影响。就是说任何事务都不可能看到一个处在不完整状态下的事务。比如说银行转帐过程中在转帐事务没有提交之前另一个转帐事务只能处于等待状态。持续性事务处理的效果能够被***保存下来。反过来说事务应当能够承受所有的失败包括服务器、进程、通信以及媒体失败等等。比如银行转帐过程中转帐后帐户的状态要能被保存下来。再来看看哪些问题会用到事务处理这里不说“银行转帐”的例子了说一个大家实际更容易遇到的“网上购书”的例子。先假设一下问题的背景网上购书某书(MySQL数据库编号为123)只剩***一本而这个时候两个用户对这本书几乎同时发出了购买请求让我们看看整个过程在具体分析之前先来看看数据表的定义create table book(book_id unsigned int(10) not null auto_increment,book_name varchar(100) not null,book_price float(5, 2) not null, #我假设每本书的价格不会超过999.99元book_number int(10) not null,primary key (book_id))typeinnodb; #engineinnodb也行对于用户甲来说他的动作稍微比乙快一点点其购买过程所触发的动作大致是这样的1. SELECT book_number FROM book WHERE book_id 123;book_number大于零确认购买行为并更新book_number2. UPDATE book SET book_number book_number - 1 WHERE book_id 123;购书成功而对于用户乙来说他的动作稍微比甲慢一点点其购买过程所触发的动作和甲相同1. SELECT book_number FROM book WHERE book_id 123;这个时候甲刚刚进行完***步的操作还没来得及做第二步操作所以book_number一定大于零2. UPDATE book SET book_number book_number - 1 WHERE book_id 123;购书成功表面上看甲乙的操作都成功了他们都买到了书但是库存只有一本他们怎么可能都成功呢再看看数据表里book_number的内容已经变成“-1”了这当然是不能允许的(实际上声明这样的列类型应该加上unsigned的属性以保证其不能为负这里是为了说明问题所以没有这样设置)好了问题陈述清楚了再来看看怎么利用事务来解决这个问题打开MySQL手册可以看到想用事务来保护你的SQL正确执行其实很简单基本就是三个语句开始提交回滚。开始START TRANSACTION或BEGIN语句可以开始一项新的事务提交COMMIT可以提交当前事务是变更成为***变更回滚ROLLBACK可以回滚当前事务取消其变更此外SET AUTOCOMMIT {0 | 1}可以禁用或启用默认的autocommit模式用于当前连接。那是不是只要用事务语句包一下我们的SQL语句就能保证正确了呢比如下面代码BEGIN;SELECT book_number FROM book WHEREbook_id123;// ...UPDATE book SETbook_numberbook_number book_number - 1 WHEREbook_id123;COMMIT;答案是否定了这样依然不能避免问题的发生如果想避免这样的情况实际应该如下BEGIN;SELECT book_number FROM book WHEREbook_id123FOR UPDATE;// ...UPDATE book SETbook_numberbook_number book_number - 1 WHEREbook_id123;COMMIT;由于加入了FOR UPDATE所以会在此条记录上加上一个行锁如果此事务没有完全结束那么其他的事务在使用SELECT ... FOR UPDATE请求的时候就会处于等待状态直到上一个事务结束它才能继续从而避免了问题的发生需要注意的是如果你其他的事务使用的是不带FOR UPDATE的SELECT语句将得不到这种保护。以上的相关内容就是对MySQL数据库与事务的介绍望你能有所收获。【编辑推荐】【责任编辑孙巧华 TEL(010)68476606】点赞 0
http://www.huolong8.cn/news/104477/

相关文章:

  • 网站开发使用什么运行软件嘉兴响应式网站
  • jsp 网站建设济南自适应网站建设
  • 上海网站建设seo公司哪家好做的网站在百度上搜不出来
  • 建设工程个人信息采集哪个网站静态网站策划书
  • 单页网站模板修改吗直播系统
  • 网站设计排行榜前十程序员用什么软件
  • php网站开发实训指导书深圳网站开发建设培训
  • 通过wordpress建站宝塔wordpress ssl证书
  • wordpress 外贸企业模板下载天津seo招聘
  • 网站信息内容建设自查4399观看视频免费哔哩哔哩
  • 网站比较分析房地产网站建设策划方案
  • 西地那非片吃了能延时多久做网站优化常用工具
  • 长春模板建站公司网上店铺怎么运营
  • 湖南益阳网站建设响应式网页设计技巧
  • 西安 h5网站建设wordpress+缩略图+api
  • 网站后台怎么上传文章罗湖区seo排名
  • 网站备案最快几天门窗网站免费模板
  • 龙胜网站建设公司医疗网站如何做优化
  • 广州做外贸网站的公司163邮箱新用户注册
  • .net做网站安全吗凡科做的网站百度能收录吗
  • wordpress网站百度数据wordpress分享服务器目录
  • 国外常用的seo站长工具龙岩房产网
  • 昆明网站建设注意事项域名回收网站
  • 网站优化人员上传电影网站源码
  • 什么公司做的网站好中国制造网介绍
  • 东营网站建设哪家好阿迪达斯网站建设的总体目标
  • 邢台专业网站建设推荐wordpress 限时 插件
  • 三元桥做网站的公司网站设置方案
  • 视频网站自己做服务器无锡网站制作哪家有名
  • 网站建设技能描述浙江华企做网站