改进Model类 改进查询方法的SQL返回机制

This commit is contained in:
thinkphp
2016-06-12 22:47:08 +08:00
parent 6d0c3a633e
commit 00b0c0f229
4 changed files with 57 additions and 56 deletions

View File

@@ -292,8 +292,7 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
protected function writeTransform($value, $type)
{
if(is_array($type)){
$param = $type[1];
$type = $type[0];
list($type,$param) = $type;
}elseif (strpos($type, ':')) {
list($type, $param) = explode(':', $type, 2);
}
@@ -328,7 +327,7 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
case 'array':
$value = (array) $value;
case 'json':
$option = !empty($param) ? (intval)$param : JSON_UNESCAPED_UNICODE;
$option = !empty($param) ? (int)$param : JSON_UNESCAPED_UNICODE;
$value = json_encode($value, $option);
break;
case 'serialize':
@@ -374,8 +373,7 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
protected function readTransform($value, $type)
{
if(is_array($type)){
$param = $type[1];
$type = $type[0];
list($type,$param) = $type;
}elseif (strpos($type, ':')) {
list($type, $param) = explode(':', $type, 2);
}

View File

@@ -28,11 +28,6 @@ abstract class Connection
/** @var PDOStatement PDO操作实例 */
protected $PDOStatement;
// 当前操作的数据表名
protected $table = '';
// 当前操作的数据对象名
protected $name = '';
/** @var string 当前SQL指令 */
protected $queryStr = '';
// 最后插入ID
@@ -322,26 +317,21 @@ abstract class Connection
* @access public
* @param string $sql sql指令
* @param array $bind 参数绑定
* @param boolean $fetch 不执行只是获取SQL
* @param boolean $master 是否在主服务器读操作
* @param bool|string $class 指定返回的数据集对象
* @return mixed
* @throws BindParamException
* @throws PDOException
*/
public function query($sql, $bind = [], $fetch = false, $master = false, $class = false)
public function query($sql, $bind = [], $master = false, $class = false)
{
$this->initConnect($master);
if (!$this->linkID) {
return false;
}
// 根据参数绑定组装最终的SQL语句
$this->queryStr = $this->getBindSql($sql, $bind);
if ($fetch) {
return $this->queryStr;
}
$this->queryStr = $this->getRealSql($sql, $bind);
//释放前次的查询结果
if (!empty($this->PDOStatement)) {
$this->free();
@@ -371,25 +361,21 @@ abstract class Connection
* @access public
* @param string $sql sql指令
* @param array $bind 参数绑定
* @param boolean $fetch 不执行只是获取SQL
* @param boolean $getLastInsID 是否获取自增ID
* @param string $sequence 自增序列名
* @return int
* @throws BindParamException
* @throws PDOException
*/
public function execute($sql, $bind = [], $fetch = false, $getLastInsID = false, $sequence = null)
public function execute($sql, $bind = [], $getLastInsID = false, $sequence = null)
{
$this->initConnect(true);
if (!$this->linkID) {
return false;
}
// 根据参数绑定组装最终的SQL语句
$this->queryStr = $this->getBindSql($sql, $bind);
$this->queryStr = $this->getRealSql($sql, $bind);
if ($fetch) {
return $this->queryStr;
}
//释放前次的查询结果
if (!empty($this->PDOStatement)) {
$this->free();
@@ -428,7 +414,7 @@ abstract class Connection
* @param array $bind 参数绑定列表
* @return string
*/
protected function getBindSql($sql, array $bind = [])
public function getRealSql($sql, array $bind = [])
{
if ($bind) {
foreach ($bind as $key => $val) {

View File

@@ -1521,7 +1521,7 @@ class Query
* @param boolean $replace 是否replace
* @param boolean $getLastInsID 是否获取自增ID
* @param string $sequence 自增序列名
* @return integer
* @return integer|string
*/
public function insert(array $data, $replace = false, $getLastInsID = false, $sequence = null)
{
@@ -1529,9 +1529,13 @@ class Query
$options = $this->parseExpress();
// 生成SQL语句
$sql = $this->builder()->insert($data, $options, $replace);
if($options['fetch_sql']){
// 获取实际执行的SQL语句
return $this->connection->getRealSql($sql,$this->bind);
}
$sequence = $sequence ?: (isset($options['sequence']) ? $options['sequence'] : null);
// 执行操作
return $this->execute($sql, $this->getBind(), $options['fetch_sql'], $getLastInsID, $sequence);
return $this->execute($sql, $this->getBind(), $getLastInsID, $sequence);
}
/**
@@ -1540,7 +1544,7 @@ class Query
* @param mixed $data 数据
* @param boolean $replace 是否replace
* @param string $sequence 自增序列名
* @return integer
* @return integer|string
*/
public function insertGetId(array $data, $replace = false, $sequence = null)
{
@@ -1551,7 +1555,7 @@ class Query
* 批量插入记录
* @access public
* @param mixed $dataSet 数据集
* @return integer
* @return integer|string
*/
public function insertAll(array $dataSet)
{
@@ -1562,8 +1566,13 @@ class Query
}
// 生成SQL语句
$sql = $this->builder()->insertAll($dataSet, $options);
// 执行操作
return $this->execute($sql, $this->getBind(), $options['fetch_sql']);
if($options['fetch_sql']){
// 获取实际执行的SQL语句
return $this->connection->getRealSql($sql,$this->bind);
}else{
// 执行操作
return $this->execute($sql, $this->getBind());
}
}
/**
@@ -1571,7 +1580,7 @@ class Query
* @access public
* @param string $fields 要插入的数据表字段名
* @param string $table 要插入的数据表名
* @return int
* @return integer|string
* @throws PDOException
*/
public function selectInsert($fields, $table)
@@ -1580,15 +1589,20 @@ class Query
$options = $this->parseExpress();
// 生成SQL语句
$sql = $this->builder()->selectInsert($fields, $table, $options);
// 执行操作
return $this->execute($sql, $this->getBind(), $options['fetch_sql']);
if($options['fetch_sql']){
// 获取实际执行的SQL语句
return $this->connection->getRealSql($sql,$this->bind);
}else{
// 执行操作
return $this->execute($sql, $this->getBind());
}
}
/**
* 更新记录
* @access public
* @param mixed $data 数据
* @return int
* @return integer|string
* @throws Exception
* @throws PDOException
*/
@@ -1622,11 +1636,13 @@ class Query
}
// 生成UPDATE SQL语句
$sql = $this->builder()->update($data, $options);
if ('' == $sql) {
return 0;
if($options['fetch_sql']){
// 获取实际执行的SQL语句
return $this->connection->getRealSql($sql,$this->bind);
}else{
// 执行操作
return '' == $sql ? 0 : $this->execute($sql, $this->getBind());
}
// 执行操作
return $this->execute($sql, $this->getBind(), $options['fetch_sql']);
}
/**
@@ -1666,13 +1682,13 @@ class Query
if (!$resultSet) {
// 生成查询SQL
$sql = $this->builder()->select($options);
if($options['fetch_sql']){
// 获取实际执行的SQL语句
return $this->connection->getRealSql($sql,$this->bind);
}
// 执行查询操作
$resultSet = $this->query($sql, $this->getBind(), $options['fetch_sql'], $options['master'], $options['fetch_class']);
$resultSet = $this->query($sql, $this->getBind(), $options['master'], $options['fetch_class']);
if (is_string($resultSet)) {
// 返回SQL
return $resultSet;
}
if ($resultSet instanceof \PDOStatement) {
// 返回PDOStatement对象
return $resultSet;
@@ -1747,13 +1763,12 @@ class Query
if (!$result) {
// 生成查询SQL
$sql = $this->builder()->select($options);
if($options['fetch_sql']){
// 获取实际执行的SQL语句
return $this->connection->getRealSql($sql,$this->bind);
}
// 执行查询
$result = $this->query($sql, $this->getBind(), $options['fetch_sql'], $options['master'], $options['fetch_class']);
if (is_string($result)) {
// 返回SQL
return $result;
}
$result = $this->query($sql, $this->getBind(), $options['master'], $options['fetch_class']);
if ($result instanceof \PDOStatement) {
// 返回PDOStatement对象
@@ -1902,8 +1917,12 @@ class Query
}
// 生成删除SQL语句
$sql = $this->builder()->delete($options);
if($options['fetch_sql']){
// 获取实际执行的SQL语句
return $this->getRealSql($sql,$this->bind);
}
// 执行操作
return $this->execute($sql, $this->getBind(), $options['fetch_sql']);
return $this->execute($sql, $this->getBind());
}
/**

View File

@@ -46,14 +46,13 @@ class Oracle extends Connection
* @access public
* @param string $sql sql指令
* @param array $bind 参数绑定
* @param boolean $fetch 不执行只是获取SQL
* @param boolean $getLastInsID 是否获取自增ID
* @param string $sequence 序列名
* @return integer
* @throws \Exception
* @throws \think\Exception
*/
public function execute($sql, $bind = [], $fetch = false, $getLastInsID = false, $sequence = null)
public function execute($sql, $bind = [], $getLastInsID = false, $sequence = null)
{
$this->initConnect(true);
if (!$this->linkID) {
@@ -62,9 +61,7 @@ class Oracle extends Connection
// 根据参数绑定组装最终的SQL语句
$this->queryStr = $this->getBindSql($sql, $bind);
if ($fetch) {
return $this->queryStr;
}
$flag = false;
if (preg_match("/^\s*(INSERT\s+INTO)\s+(\w+)\s+/i", $sql, $match)) {
if(is_null($sequence)){
@@ -72,6 +69,7 @@ class Oracle extends Connection
}
$flag = (boolean) $this->query("SELECT * FROM all_sequences WHERE sequence_name='" . strtoupper($sequence) . "'");
}
//释放前次的查询结果
if (!empty($this->PDOStatement)) {
$this->free();