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-并发和数据类型的更多相关文章

  1. Mysql学习笔记(一)数据类型

    原文:Mysql学习笔记(一)数据类型 学习内容: Mysql基本数据类型. 1.数字类型.. i.整型     Mysql数据类型             含义(有符号)     tinyint(m ...

  2. <<操作系统精髓与设计原理>>读书笔记(一) 并发性:互斥与同步(1)

    <<操作系统精髓与设计原理>>读书笔记(一) 并发性:互斥与同步 并发问题是所有问题的基础,也是操作系统设计的基础.并发包括很多设计问题,其中有进程间通信,资源共享与竞争,多个 ...

  3. [笔记][Java7并发编程实战手冊]系列文件夹

    推荐学习多线程之前要看的书. [笔记][思维导图]读深入理解JAVA内存模型整理的思维导图文章里面的思维导图或则相应的书籍.去看一遍. 能理解为什么并发编程就会出现故障. Java7并发编程实战手冊 ...

  4. 2016年第2周读书笔记与工作笔记 scrollIntoView()与datalist元素

    这一周主要是看了html5网页开发实例与javascript 高级程序设计,供以后翻阅查找.  html5网页开发实例第1章与第二章的2.1部分: 第1章内容: html5在w3c的发展史. 浏览器的 ...

  5. MYSQL基础笔记(六)- 数据类型一

    数据类型(列类型) 所谓数据烈性,就是对数据进行统一的分类.从系统角度出发时为了能够使用统一的方式进行管理,更好的利用有限的空间. SQL中讲数据类型分成三大类:1.数值类型,2.字符串类型和时间日期 ...

  6. javascript - 工作笔记 (事件四)

    在javascript - 工作笔记 (事件绑定二)篇中,我将事件的方法做了简单的包装,  JavaScript Code  12345   yx.bind(item, "click&quo ...

  7. Mysql学习笔记(二)数据类型 补充

    原文:Mysql学习笔记(二)数据类型 补充 PS:简单的补充一下数据类型里的String类型以及列类型... 学习内容: 1.String类型 2.列类型存储需求 String类型: i.char与 ...

  8. 工作笔记3.手把手教你搭建SSH(struts2+hibernate+spring)环境

    上文中我们介绍<工作笔记2.软件开发经常使用工具> 从今天開始本文将教大家怎样进行开发?本文以搭建SSH(struts2+hibernate+spring)框架为例,共分为3步: 1)3个 ...

  9. Java并发编程的艺术读书笔记(2)-并发编程模型

    title: Java并发编程的艺术读书笔记(2)-并发编程模型 date: 2017-05-05 23:37:20 tags: ['多线程','并发'] categories: 读书笔记 --- 1 ...

随机推荐

  1. KNN近邻算法

    K近邻(KNN,k-NearestNeighbor)分类算法是数据挖掘分类技术中最简单的方法之一.所谓K最近邻,就是k个最近的邻居的意思,说的是每个样本都可以用它最接近的k个邻居来代表.kNN算法的核 ...

  2. getview不执行

    <FrameLayout android:layout_width="match_parent" android:layout_height="match_pare ...

  3. 批量修改sql server 2008的架构

    --批量修改架构.名称为XJADMINATT的所有表修改为dbo-- --把执行的结果,拷贝到命令行,执行命令即可-- declare @name sysname declare csr1 curso ...

  4. [zz] Principal Components Analysis (PCA) 主成分分析

    我理解PCA应该分为2个过程:1.求出降维矩阵:2.利用得到的降维矩阵,对数据/特征做降维. 这里分成了两篇博客,来做总结. http://matlabdatamining.blogspot.com/ ...

  5. VR外包团队:长年承接VR虚拟现实外包(应用、游戏、视频、漫游等)

    北京动点飞扬软件,从事外包业务五年,长年承接全景VR视频,全景普通视频外包. 以下是全景VR视频案例(可操作,人不动景物不动,人移动,景物跟随) 欢迎联系我们QQ:372900288 TEL:1391 ...

  6. javascript的一点学习

    最近用vue.js用的很爽,在全栈开发的路上一路狂奔,发现后台跟前台一起确实更有意义. 记录一个比较有意思的bug: 目标是对一个全局的paramList进行json格式化显示.代码借鉴了 http: ...

  7. Sql Server分割字符串函数

    -- Description: 分割字符串函数 -- SELECT * FROM dbo.Split('a,b,c,d,e,f,g',',') -- ========================= ...

  8. 常见jquery插件

    1.JQuery Tooltipster 2.Bootstrap 3.jQuery UI 1.10

  9. python中的单引号,双引号,三引号

    转载自: http://blog.csdn.net/wanghai__/article/details/6285310 先说1双引号与3个双引号的区别,双引号所表示的字符串通常要写成一行 如: s1 ...

  10. php源码之遍历目录下的所有的文件

    <?php //遍历目录下的所有的文件 -- 递归调用 // http://www.manongjc.com/article/1495.html function get_all_file1($ ...