php工作笔记8-并发和数据类型
1、mysql在进行数据的修改时,并发情况下:
$RoundsRows=$modelRounds->where("id=$roundsID and (sendMoney + $amount <=
TotalMoney)")->setInc('SendMoney',$amount);
2、在mysql事务中,会有幻读,在事务中可以并发读,某一资源,
$modelOrder->startTrans(); //开启事务操作
$NOW=date("Y-m-d H:i:s");
$maxPayConfirmID=$modelOrder->max("PayConfirmID");
$maxPayConfirmID++;
$saveArr_order=array(
"OrderStatus" =>1,
"PayStatus" =>2,
"PayTime" =>$NOW,
"ConfirmTime" =>$NOW,
"PayConfirmID"=>$maxPayConfirmID
);
$saveRows=$modelOrder->where("OrderSn='$out_trade_no' AND OrderStatus=0
AND PayStatus=1")->save($saveArr_order);
修改为下面就好了,在事务中,不可以并发写,
$modelOrder->startTrans(); //开启事务操作
$NOW=date("Y-m-d H:i:s");
//2.订单操作记录
$addArr_oaction=array(
"OrderSn" =>$out_trade_no,
"ActionUser" =>0,
"OrderStatus" =>1,
"CreateTime" =>$NOW
);
$add_OactionID=$modelOaction->add($addArr_oaction);
if(empty($add_OactionID))
{
$modelOrder->rollback();
$this->recordLogs("wxpay_oaction_fail","更改订单操作失败","更改订单
操作失败");
$this->stopCallback();
}
//1.更改订单,已确认,已付款
$maxPayConfirmID=$add_OactionID;//$modelOrder->max("PayConfirmID");
$saveArr_order=array(
"OrderStatus" =>1,
"PayStatus" =>2,
"PayTime" =>$NOW,
"ConfirmTime" =>$NOW,
"PayConfirmID"=>$maxPayConfirmID
);
$saveRows=$modelOrder->where("OrderSn='$out_trade_no' AND OrderStatus=0
AND PayStatus=1")->save($saveArr_order);
3、double转成int会有定都丢失
转换为string再转换为int
这个是PHP document中给出来的提示:
简单的十进制分数如同 0.1 或 0.7 不能在不丢失一点点精度的情况下转换为内部二进制的格
式。
floor(( 0.1 + 0.7 ) * 10) 返回 7 而不是8,
(int)(( 0.1 + 0.7 ) * 10) 返回7而不是8.
对这种现象的解释是“因为该结果内部的表示其实是类似 7.9”。
所以得到的结论是:
所以永远不要相信浮点数结果精确到了最后一位,也永远不要比较两个浮点数是否相等。
决不要将未知的分数强制转换为Int。
(int)round( 0.1 + 0.7 ) * 10) 这样似乎就安全了。
在有大量乘除或者是中间值为float类型时,为了数值精度还是使用BC math函数了。
php工作笔记8-并发和数据类型的更多相关文章
- Mysql学习笔记(一)数据类型
原文:Mysql学习笔记(一)数据类型 学习内容: Mysql基本数据类型. 1.数字类型.. i.整型 Mysql数据类型 含义(有符号) tinyint(m ...
- <<操作系统精髓与设计原理>>读书笔记(一) 并发性:互斥与同步(1)
<<操作系统精髓与设计原理>>读书笔记(一) 并发性:互斥与同步 并发问题是所有问题的基础,也是操作系统设计的基础.并发包括很多设计问题,其中有进程间通信,资源共享与竞争,多个 ...
- [笔记][Java7并发编程实战手冊]系列文件夹
推荐学习多线程之前要看的书. [笔记][思维导图]读深入理解JAVA内存模型整理的思维导图文章里面的思维导图或则相应的书籍.去看一遍. 能理解为什么并发编程就会出现故障. Java7并发编程实战手冊 ...
- 2016年第2周读书笔记与工作笔记 scrollIntoView()与datalist元素
这一周主要是看了html5网页开发实例与javascript 高级程序设计,供以后翻阅查找. html5网页开发实例第1章与第二章的2.1部分: 第1章内容: html5在w3c的发展史. 浏览器的 ...
- MYSQL基础笔记(六)- 数据类型一
数据类型(列类型) 所谓数据烈性,就是对数据进行统一的分类.从系统角度出发时为了能够使用统一的方式进行管理,更好的利用有限的空间. SQL中讲数据类型分成三大类:1.数值类型,2.字符串类型和时间日期 ...
- javascript - 工作笔记 (事件四)
在javascript - 工作笔记 (事件绑定二)篇中,我将事件的方法做了简单的包装, JavaScript Code 12345 yx.bind(item, "click&quo ...
- Mysql学习笔记(二)数据类型 补充
原文:Mysql学习笔记(二)数据类型 补充 PS:简单的补充一下数据类型里的String类型以及列类型... 学习内容: 1.String类型 2.列类型存储需求 String类型: i.char与 ...
- 工作笔记3.手把手教你搭建SSH(struts2+hibernate+spring)环境
上文中我们介绍<工作笔记2.软件开发经常使用工具> 从今天開始本文将教大家怎样进行开发?本文以搭建SSH(struts2+hibernate+spring)框架为例,共分为3步: 1)3个 ...
- Java并发编程的艺术读书笔记(2)-并发编程模型
title: Java并发编程的艺术读书笔记(2)-并发编程模型 date: 2017-05-05 23:37:20 tags: ['多线程','并发'] categories: 读书笔记 --- 1 ...
随机推荐
- fastdfs 安装配置
介绍文档 1.安装 # wget # tar xf download # cd FastDFS/ # ./make.sh 运行文件 有报错信息 compilation terminated. ...
- python之错误和异常
错误 分为语法错误和逻辑错误,如下: 语法错误指示软件的结构上有错误,导致不能被解释器解释或编译器编译. 逻辑错误可能是由于不完整或是不合法的输入所致,或者是无法生成.计算.或是输出结果需要的过程无法 ...
- 一种扩大View点击范围的方法
Rect rect = new Rect();mBt0.getHitRect(rect); rect.bottom += 400; TouchDelegate touchDelegate = new ...
- EL总结
El: 1.el表达式语言(是什么) 2.el是书写到jsp页面 3.el语法格式${ } 4.el算数运算(+,-,*,/,%), 逻辑运算(&&,||,!), 关系运算(>, ...
- 真机调试时遇到“Could not launch *** process launch failed: Security”的解决办法
半年没写ios程序了,打算重新将这块技术捡回来.谁知道写的第一个测试程序在真机上就跑出来因为安全问题不能加载的情况. ios的版本是9.2的.看提示信息是app的启动被ios的安全机制阻挡了. 在手机 ...
- 【学】React的学习之旅1
React的学习之旅1 单标签要有斜杠代表结束 用React.createClass()方法时,赋值后的组件名称首字母一定要大写 一定要先定义组件,再用ReactDOM.render调用 组件里ren ...
- oracle之sequence详解
Oracle提供了sequence对象,由系统提供自增长的序列号,每次取的时候它会自动增加,通常用于生成数据库数据记录的自增长主键或序号的地方. sequence的创建需要用户具有create seq ...
- maven Error resolving version for plugin 'org.apache.maven.plugins:maven-eclipse-plugin' from the repositories 解决
报错:Error resolving version for plugin 'org.apache.maven.plugins:maven-eclipse-plugin' from the repos ...
- [Linux] IP绑定解释 BindIp
一.缘由: 今天安装Mongodb,本来想限制只能内网或者某几台机器可以访问,看到配置文件有个net.bindIp选项, 就自以为是的认为,他可以像nginx那样限制访问来源IP,其实大错特错.这里配 ...
- contains 方法
不管在c#中还是java中,很多类型都有contains方法.它的原理是什么? 看一个java的例子 http://blog.csdn.net/fwwdn/article/details/674684 ...