mirror of
https://gitee.com/fastadminnet/framework.git
synced 2026-07-01 12:42:48 +08:00
改进Query类的find和select方法的默认值
This commit is contained in:
@@ -248,7 +248,7 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
|
||||
$value = $_SERVER['REQUEST_TIME'];
|
||||
break;
|
||||
}
|
||||
} elseif (is_string($this->autoWriteTimestamp) && in_array(strtolower($this->autoWriteTimestamp),['datetime','date','timestamp'])) {
|
||||
} elseif (is_string($this->autoWriteTimestamp) && in_array(strtolower($this->autoWriteTimestamp), ['datetime', 'date', 'timestamp'])) {
|
||||
$value = date($this->dateFormat, $_SERVER['REQUEST_TIME']);
|
||||
} else {
|
||||
$value = $_SERVER['REQUEST_TIME'];
|
||||
@@ -282,9 +282,9 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
|
||||
*/
|
||||
protected function writeTransform($value, $type)
|
||||
{
|
||||
if(is_array($type)){
|
||||
list($type,$param) = $type;
|
||||
}elseif (strpos($type, ':')) {
|
||||
if (is_array($type)) {
|
||||
list($type, $param) = $type;
|
||||
} elseif (strpos($type, ':')) {
|
||||
list($type, $param) = explode(':', $type, 2);
|
||||
}
|
||||
switch ($type) {
|
||||
@@ -318,12 +318,12 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
|
||||
case 'array':
|
||||
$value = (array) $value;
|
||||
case 'json':
|
||||
$option = !empty($param) ? (int)$param : JSON_UNESCAPED_UNICODE;
|
||||
$option = !empty($param) ? (int) $param : JSON_UNESCAPED_UNICODE;
|
||||
$value = json_encode($value, $option);
|
||||
break;
|
||||
case 'serialize':
|
||||
$value = serialize($value);
|
||||
break;
|
||||
break;
|
||||
}
|
||||
return $value;
|
||||
}
|
||||
@@ -363,9 +363,9 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
|
||||
*/
|
||||
protected function readTransform($value, $type)
|
||||
{
|
||||
if(is_array($type)){
|
||||
list($type,$param) = $type;
|
||||
}elseif (strpos($type, ':')) {
|
||||
if (is_array($type)) {
|
||||
list($type, $param) = $type;
|
||||
} elseif (strpos($type, ':')) {
|
||||
list($type, $param) = explode(':', $type, 2);
|
||||
}
|
||||
switch ($type) {
|
||||
@@ -399,7 +399,7 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
|
||||
break;
|
||||
case 'serialize':
|
||||
$value = unserialize($value);
|
||||
break;
|
||||
break;
|
||||
}
|
||||
return $value;
|
||||
}
|
||||
@@ -636,7 +636,7 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
|
||||
public function saveAll($dataSet)
|
||||
{
|
||||
$result = 0;
|
||||
$db = $this->db();
|
||||
$db = $this->db();
|
||||
$db->startTrans();
|
||||
try {
|
||||
foreach ($dataSet as $data) {
|
||||
@@ -881,7 +881,7 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
|
||||
* @return static
|
||||
* @throws exception\DbException
|
||||
*/
|
||||
public static function get($data = '', $with = [], $cache = false)
|
||||
public static function get($data = null, $with = [], $cache = false)
|
||||
{
|
||||
$query = self::parseQuery($data, $with, $cache);
|
||||
return $query->find($data);
|
||||
@@ -896,7 +896,7 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
|
||||
* @return static[]|false
|
||||
* @throws exception\DbException
|
||||
*/
|
||||
public static function all($data = [], $with = [], $cache = false)
|
||||
public static function all($data = null, $with = [], $cache = false)
|
||||
{
|
||||
$query = self::parseQuery($data, $with, $cache);
|
||||
return $query->select($data);
|
||||
@@ -915,13 +915,13 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
|
||||
$result = self::with($with)->cache($cache);
|
||||
if (is_array($data) && key($data) !== 0) {
|
||||
$result = $result->where($data);
|
||||
$data = [];
|
||||
$data = null;
|
||||
} elseif ($data instanceof \Closure) {
|
||||
call_user_func_array($data, [ & $result]);
|
||||
$data = [];
|
||||
$data = null;
|
||||
} elseif ($data instanceof Query) {
|
||||
$result = $data->with($with)->cache($cache);
|
||||
$data = [];
|
||||
$data = null;
|
||||
}
|
||||
return $result;
|
||||
}
|
||||
@@ -938,10 +938,10 @@ abstract class Model implements \JsonSerializable, \ArrayAccess
|
||||
$query = $model->db();
|
||||
if (is_array($data) && key($data) !== 0) {
|
||||
$query->where($data);
|
||||
$data = [];
|
||||
$data = null;
|
||||
} elseif ($data instanceof \Closure) {
|
||||
call_user_func_array($data, [ & $query]);
|
||||
$data = [];
|
||||
$data = null;
|
||||
}
|
||||
$resultSet = $query->select($data);
|
||||
$count = 0;
|
||||
|
||||
@@ -1703,13 +1703,13 @@ class Query
|
||||
* @throws Exception
|
||||
* @throws PDOException
|
||||
*/
|
||||
public function select($data = [])
|
||||
public function select($data = null)
|
||||
{
|
||||
if ($data instanceof Query) {
|
||||
return $data->select();
|
||||
} elseif ($data instanceof \Closure) {
|
||||
call_user_func_array($data, [ & $this]);
|
||||
$data = [];
|
||||
$data = null;
|
||||
}
|
||||
// 分析查询表达式
|
||||
$options = $this->parseExpress();
|
||||
@@ -1717,7 +1717,7 @@ class Query
|
||||
if (false === $data) {
|
||||
// 用于子查询 不查询只返回SQL
|
||||
$options['fetch_sql'] = true;
|
||||
} elseif (!empty($data)) {
|
||||
} elseif (!is_null($data)) {
|
||||
// 主键条件分析
|
||||
$this->parsePkWhere($data, $options);
|
||||
}
|
||||
@@ -1790,18 +1790,18 @@ class Query
|
||||
* @throws Exception
|
||||
* @throws PDOException
|
||||
*/
|
||||
public function find($data = [])
|
||||
public function find($data = null)
|
||||
{
|
||||
if ($data instanceof Query) {
|
||||
return $data->find();
|
||||
} elseif ($data instanceof \Closure) {
|
||||
call_user_func_array($data, [ & $this]);
|
||||
$data = [];
|
||||
$data = null;
|
||||
}
|
||||
// 分析查询表达式
|
||||
$options = $this->parseExpress();
|
||||
|
||||
if (!empty($data) || 0 === $data) {
|
||||
if (!is_null($data)) {
|
||||
// AR模式分析主键条件
|
||||
$this->parsePkWhere($data, $options);
|
||||
}
|
||||
|
||||
@@ -44,7 +44,7 @@ class Merge extends Model
|
||||
* @param bool $cache 是否缓存
|
||||
* @return \think\Model
|
||||
*/
|
||||
public static function get($data = '', $with = [], $cache = false)
|
||||
public static function get($data = null, $with = [], $cache = false)
|
||||
{
|
||||
$query = self::parseQuery($data, $with, $cache);
|
||||
$query = self::attachQuery($query);
|
||||
@@ -106,7 +106,7 @@ class Merge extends Model
|
||||
* @param string $with 关联预查询
|
||||
* @return array|false|string
|
||||
*/
|
||||
public static function all($data = [], $with = [], $cache = false)
|
||||
public static function all($data = null, $with = [], $cache = false)
|
||||
{
|
||||
$query = self::parseQuery($data, $with, $cache);
|
||||
$query = self::attachQuery($query);
|
||||
@@ -193,7 +193,7 @@ class Merge extends Model
|
||||
unset($data[$pk]);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// 处理模型数据
|
||||
$data = $this->parseData($this->name, $this->data);
|
||||
// 写入主表数据
|
||||
|
||||
Reference in New Issue
Block a user