ThinkPHP5数据库实例详解 /自增自减与延时更新

自增自减与延时更新

setInc 和 setDec 方法

1、功能:字段的值的自增、自减与延时更新

1.自增自减针对可计算的字段类型:数值型和日期时间型;
2.如对字符型字段自增,将会将该字段强行更新为自增值,如:1;
3.自增自减操作的条件,必须在该方法之前设置。

2、源码:/thinkphp/library/think/Query.php

  • 下面仅以:setInc方法为例展示:

源码显示:没有更新条件时,该方法拒绝执行,确保数据安全

3、参数与返回值:

  • 该方法可接受三个参数:
序号 名称 类型
参数1 字段名称 数值或日期时间型
参数2 步长值 整形,默认为1,可为负值
参数3 延时秒数 整形,必须正值
  • 返回值:受影响的记录数量。

4、实例演示(以setInc自增为例):

任务1:[单记录自增]
将tp5_staff表中id=1010的员工年龄加10;

1.先查看一下id = 1010 员工的当前age年龄字段的值
find(1010)); } }
2.结果如下
array(7) { ["id"] => int(1010) ["name"] => string(9) "欧阳峰" ["sex"] => int(1) ["age"] => int(18) // 年龄为 18 岁 ["salary"] => float(4900) ["dept"] => int(2) ["hiredate"] => string(10) "2013-09-22" }
3.Index.php 控制器代码如下:
 where('id',1010) -> setInc('age',10); //查询id=1010的记录 dump(Db::table('tp5_staff')->find(1010)); } }
4、再次查看id=1010的记录,检查是否更新成功
array(7) { ["id"] => int(1010) ["name"] => string(9) "欧阳峰" ["sex"] => int(1) ["age"] => int(28) //之前为18,现在已更新为28,自增成功 ["salary"] => float(4900) ["dept"] => int(2) ["hiredate"] => string(10) "2013-09-22" }


任务2:[多记录自增]
将tp5_staff表中id=1005到1007三条记录的员工入职日期减3天(负值实现);

  • 先查看未更新前的三个员工的入职日期

  • Index.php 控制器代码:
 where('id','between','1005,1007') -> setInc('hiredate',-3); // 2.查看更新结果 dump(Db::table('tp5_staff')->where('id','between','1005,1007')->select()); } }
  • 运行结果:
array(3) { [0] => array(7) { ["id"] => int(1005) ["name"] => string(6) "武松" ["sex"] => int(0) ["age"] => int(19) ["salary"] => float(2400) ["dept"] => int(3) ["hiredate"] => string(10) "2010-07-18" //由2010-07-21变成2010-07-18 } [1] => array(7) { ["id"] => int(1006) ["name"] => string(9) "西门庆" ["sex"] => int(0) ["age"] => int(90) ["salary"] => float(19801) ["dept"] => int(2) ["hiredate"] => string(10) "2015-12-28" //由2015-12-31变成2015-12-28 } [2] => array(7) { ["id"] => int(1007) ["name"] => string(9) "潘金莲" ["sex"] => int(0) ["age"] => int(39) ["salary"] => float(8567) ["dept"] => int(3) ["hiredate"] => string(10) "2016-03-17" //由2016-03-20变成2016-03-17 } }
  • 此时,表中数据也变更为:

5、总结:

1.我们仅以setInc方法举例,setDec方法与之类似,不再举例;
2.通过设置自增自减步长值的正负值,这二个方法完全可以互换,上例中已体现;
3.该方法在大量数据自增自减时,效率很高,推荐使用;
4.延时更新不便演示,同学们完成可以自己完成。

6、db助手函数

db助手函数仅仅是简化了数据表的选择,其它地方都完全一样,请同学们课后自己完成,下面为例子,请仿照改写:

 where('id',1010) -> setInc('age',10); //查询id=1010的记录 dump(db('staff')->find(1010)); } }