이 글은 주로 좋은 참고 가치가 있는 thinkphp3.2.0 setInc 메소드의 소스 코드에 대한 종합적인 분석을 공유합니다. 편집자를 따라 살펴보겠습니다. 모두에게 도움이 되기를 바랍니다.
먼저 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 )" } }
첫 번째 단계는 setInc 메소드의 소스 코드를 찾는 것입니다.
여기서 phpstrom 전역 검색 메소드를 사용하여 setInc가 projThinkPHPLibraryThinkModel.class.php
/** * 字段值增长 * @access public * @param string $field 字段名 * @param integer $step 增长值 * @return boolean */ public function setInc($field,$step=1) { return $this->setField($field,array('exp',$field.'+'.$step)); }
아래에 있음을 확인했습니다. setField가 다음과 같은 것을 볼 수 있습니다. 여기서 메소드를 사용한 다음 exp 사용자 정의 표현식을 사용하여 $field = $field + $step을 설정합니다. 이 시점에서 우리는 원리에 대해 조금 이해했습니다.
하지만 다시 질문이 생깁니다. setField는 어떻게 구현되나요? 동일한 파일에서 setField 메소드를 찾으세요.
/** * 设置记录的某个字段值 * 支持使用数据库字段和方法 * @access public * @param string|array $field 字段名 * @param string $value 字段值 * @return boolean */ public function setField($field,$value='') { if(is_array($field)) { $data = $field; }else{ $data[$field] = $value; } return $this->save($data); }
여기서 일반적으로 사용되는 save 메소드를 볼 수 있습니다. 여기서 $data[$field] = $value; 는 실제로 $data['test_number'] = array("exp" ," test_number+2")
그런 다음 가장 일반적으로 사용되는 저장 방법을 살펴보겠습니다.
/** * 保存数据 * @access public * @param mixed $data 数据 * @param array $options 表达式 * @return boolean */ public function save($data='',$options=array()) { if(empty($data)) { // 没有传递数据,获取当前数据对象的值 if(!empty($this->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 스플라이싱을 위해 매개변수를 문자열 배열로 변환하고, 후자는 projtptestThinkPHPLibraryThinkDb.class.php 아래에서 업데이트 메소드를 호출합니다.
/** * 更新记录 * @access public * @param mixed $data 数据 * @param array $options 表达式 * @return false | integer */ public function update($data,$options) { $this->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())); }
결국 projThinkPHPLibraryThinkDbDriverMysql.class는 실제로 사용되는 .php 드라이버 클래스의 실행 메소드입니다.
/** * 执行语句 * @access public * @param string $str sql指令 * @return integer|false */ public function execute($str) { $this->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 페이징 사용자 정의 스타일 예제 공유 구현
Thinkphp3.2 방법으로 여러 파일 업로드 시 파일 하나만 업로드하는 문제 해결
위 내용은 thinkphp3.2.0 setInc 메소드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!