ThinkPHP   发布时间:2022-04-12  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了thinkphp3.2.0 setInc方法 源码全面解析大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

BACkground-color: #ccffcc">

我们先来看一下seTinc的官方示例:

thinkphp3.2.0 setInc方法 源码全面解析

需要一个字段和一个自增的值(默认为1)

我们通过下面这个例子来一步步分析他的底层是怎么实现的:

php namespace Home\Controller; use Think\Controller;

class TESTController extends Controller {
public function test() {
$tb_test = M('test');
$tb_test->where(['id'=>1])->seTinc('test_number',2); //每次添加2
dump($tb_test->getLastSql());
//String(67) "updatE tb_test SET test_number=test_number+2 WHERE ( id = 1 )"
}
}

BACkground-color: #ccffcc">

第一步肯定是要找到seTinc方法的源码:

这里我用到了phpstrom全局搜索的方法,找到了seTinc是在proj\Thinkphp\Library\Think\Model.class.php

setField($field,array('exp',$field.'+'.$step)); }

可以看到这里用到了setField这个方法,然后用exp自定义表达式设置 $field = $field + $step 到这里,我们稍微了解了一点原理。

BACkground-color: #ccffcc">

可是问题又来了setField又是怎么实现的呢?在同个文件下,找到setField方法:

save($data); }

这里我们看到了常用到的save方法,这里的 $data[$field] = $value; 其实就是 $data['test_number'] = array("exp","test_number+2")

BACkground-color: #ccffcc">

接着来看最常用的save方法:

data)) { $data = $this->data; // 重置数据 $this->data = array(); }else{ $this->error = L('_DATA_TYPE_INVALID_'); return false; } } // 数据处理 $data = $this->_facade($data); // 分析表达式 $options = $this->_parseOptions($options); $pk = $this->getPk(); if(!isset($options['where']) ) { // 如果存在主键数据 则自动作为更新条件 if(isset($data[$pk])) { $where[$pk] = $data[$pk]; $options['where'] = $where; unset($data[$pk]); }else{ // 如果没有任何更新条件则不执行 $this->error = L('_OPERATION_WRONG_'); return false; } } if(is_array($options['where']) && isset($options['where'][$pk])){ $pkValue = $options['where'][$pk]; } if(false === $this->_before_update($data,$options)) { return false; } $result = $this->db->update($data,$options); if(false !== $result) { if(isset($pkvalue)) $data[$pk] = $pkValue; $this->_after_update($data,$options); } return $result; }

最主要是的$options = $this->_parseOptions($options);和$result = $this->db->update($data,$options); 前者把参数转换成用于拼接sql的字符串数组,后者调用了proj\tptest\Thinkphp\Library\Think\Db.class.php下的update方法:

@model = $options['model']; $sql = 'updatE ' .$this->parseTable($options['table']) .$this->parseSet($data) .$this->parseWhere(!empty($options['where'])?$options['where']:'') .$this->parseOrder(!empty($options['order'])?$options['order']:'') .$this->parseLimit(!empty($options['limit'])?$options['limit']:'') .$this->parseLock(isset($options['lock'])?$options['lock']:falsE) .$this->parseComment(!empty($options['comment'])?$options['comment']:''); return $this->execute($sql,$this->parseBind(!empty($options['bind'])?$options['bind']:array())); }

最后其实就是用到了proj\Thinkphp\Library\Think\Db\Driver\Mysql.class.php这个驱动类的execute方法。

initConnect(true); if ( !$this->_linkID ) return false; $this->queryStr = $str; //释放前次的查询结果 if ( $this->queryID ) { $this->free(); } N('db_write',1); // 记录开始执行时间 G('queryStartTime'); $result = mysql_query($str,$this->_linkID) ; $this->debug(); if ( false === $result) { $this->error(); return false; } else { $this->numRows = mysql_affected_rows($this->_linkID); $this->lasTinsID = mysql_insert_id($this->_linkID); return $this->numRows; } }

最后用最底层的mysql_query执行sql语句。

到此为止,seTinc的源码已经大致过了一遍了。想必大家对seTinc如何执行也更了解了一点。

以上这篇thinkphp3.2.0 seTinc方法 源码全面解析就是小编分享给大家的全部内容了,希望能给大家一个参,也希望大家多多支持菜鸟教程。

大佬总结

以上是大佬教程为你收集整理的thinkphp3.2.0 setInc方法 源码全面解析全部内容,希望文章能够帮你解决thinkphp3.2.0 setInc方法 源码全面解析所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:3.2.0thinkphp