ThinkPHP 模型方法 setInc() 和 setDec() 使用详解

Posted 52PHP

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ThinkPHP 模型方法 setInc() 和 setDec() 使用详解相关的知识,希望对你有一定的参考价值。

对于数字字段的加减,可以直接使用 setInc()setDec() 方法

Thinkphp 内置了对统计数据(数字字段)的更新方法:

setInc():将数字字段值增加

setDec():将数字字段值减少

setInc()

ThinkPHP setInc() 方法将数字字段值增加。

例子:

<?php
public function update() {
	header("Content-Type:text/html; charset=utf-8");
	$result = M("User")->where(‘uid = 2‘)->setInc(‘score‘, 3);
	if ($result !== false) {
		echo ‘数据更新成功!‘;
	} else {
		echo ‘没更新任何数据!‘;
	}
}

上面例子执行的 SQL 语句为:

UPDATE user SET score=score+3 WHERE uid = 2

setInc() 方法中最后一个参数为数字字段增加的值,如果省略则默认增加 1 。

 

setDec()

setDec() 方法将数字字段值减少。

例子:

<?php
public function update() {
	header("Content-Type:text/html; charset=utf-8");
	$result = M("User")->where(‘uid = 2‘)->setDec(‘score‘, 3);
	if ($result !== false) {
		echo ‘数据更新成功!‘;
	} else {
		echo ‘没更新任何数据!‘;
	}
}

上面例子执行的 SQL 语句为:

UPDATE user SET score=score-3 WHERE uid = 2

setDec() 方法中最后一个参数为数字字段减少的值,如果省略则默认减少 1 。

 

提示

在 ThinkPHP 3.0 版本中,setInc()setDec() 方法取消了条件参数,因此必须配合 where() 方法一起使用。setInc() 与 setDec() 方法也支持连贯操作,从而可以构造更加复杂的更新条件。

以上是关于ThinkPHP 模型方法 setInc() 和 setDec() 使用详解的主要内容,如果未能解决你的问题,请参考以下文章

thinkphp的setinc方法有没有处理浮点数

thinkphp中的setIncsetDec方法

关于在ThinkPHP中运用setInc和setDec两个函数

thinkphp 登陆时怎么让登陆的次数加1 表名为op_test 登陆次数的字段为 number

thinkphp执行一次setInc('click_num','id='.$cms_id,1),'click_num'自动加3,不知道什么问题,求指教。

thinkphp-自增或自减一个字段的值