ComposerUpdate

This commit is contained in:
Anyon 2019-11-19 10:16:04 +08:00
parent d28b3900d7
commit ab20784645
44 changed files with 208 additions and 150 deletions

18
composer.lock generated
View File

@ -595,16 +595,16 @@
}, },
{ {
"name": "topthink/think-orm", "name": "topthink/think-orm",
"version": "v2.0.27", "version": "v2.0.28",
"source": { "source": {
"type": "git", "type": "git",
"url": "https://github.com/top-think/think-orm.git", "url": "https://github.com/top-think/think-orm.git",
"reference": "02affaaccade2cdd8bbb2d2f5d15e46113e6eb50" "reference": "ff5f112f5559497222f2716385b5a709ab82741b"
}, },
"dist": { "dist": {
"type": "zip", "type": "zip",
"url": "https://api.github.com/repos/top-think/think-orm/zipball/02affaaccade2cdd8bbb2d2f5d15e46113e6eb50", "url": "https://api.github.com/repos/top-think/think-orm/zipball/ff5f112f5559497222f2716385b5a709ab82741b",
"reference": "02affaaccade2cdd8bbb2d2f5d15e46113e6eb50", "reference": "ff5f112f5559497222f2716385b5a709ab82741b",
"shasum": "", "shasum": "",
"mirrors": [ "mirrors": [
{ {
@ -642,7 +642,7 @@
"database", "database",
"orm" "orm"
], ],
"time": "2019-10-23T02:16:50+00:00" "time": "2019-11-17T07:53:45+00:00"
}, },
{ {
"name": "topthink/think-template", "name": "topthink/think-template",
@ -783,12 +783,12 @@
"source": { "source": {
"type": "git", "type": "git",
"url": "https://github.com/zoujingli/ThinkLibrary.git", "url": "https://github.com/zoujingli/ThinkLibrary.git",
"reference": "9e636a7be3d7c468cb73c40c48835bf51cef6864" "reference": "bb5ec20e7047c582f1ae6e5faea7e3ecdf5a2da6"
}, },
"dist": { "dist": {
"type": "zip", "type": "zip",
"url": "https://api.github.com/repos/zoujingli/ThinkLibrary/zipball/9e636a7be3d7c468cb73c40c48835bf51cef6864", "url": "https://api.github.com/repos/zoujingli/ThinkLibrary/zipball/bb5ec20e7047c582f1ae6e5faea7e3ecdf5a2da6",
"reference": "9e636a7be3d7c468cb73c40c48835bf51cef6864", "reference": "bb5ec20e7047c582f1ae6e5faea7e3ecdf5a2da6",
"shasum": "", "shasum": "",
"mirrors": [ "mirrors": [
{ {
@ -832,7 +832,7 @@
], ],
"description": "ThinkPHP v6.0 Development Library", "description": "ThinkPHP v6.0 Development Library",
"homepage": "http://framework.thinkadmin.top", "homepage": "http://framework.thinkadmin.top",
"time": "2019-11-18T11:43:36+00:00" "time": "2019-11-19T02:13:00+00:00"
} }
], ],
"packages-dev": [], "packages-dev": [],

2
vendor/autoload.php vendored
View File

@ -4,4 +4,4 @@
require_once __DIR__ . '/composer/autoload_real.php'; require_once __DIR__ . '/composer/autoload_real.php';
return ComposerAutoloaderInitdc48cac423beab724a7102138067b2f9::getLoader(); return ComposerAutoloaderInit927a7ea59f5590e9e57c74d6ecc97142::getLoader();

View File

@ -2,7 +2,7 @@
// autoload_real.php @generated by Composer // autoload_real.php @generated by Composer
class ComposerAutoloaderInitdc48cac423beab724a7102138067b2f9 class ComposerAutoloaderInit927a7ea59f5590e9e57c74d6ecc97142
{ {
private static $loader; private static $loader;
@ -19,15 +19,15 @@ class ComposerAutoloaderInitdc48cac423beab724a7102138067b2f9
return self::$loader; return self::$loader;
} }
spl_autoload_register(array('ComposerAutoloaderInitdc48cac423beab724a7102138067b2f9', 'loadClassLoader'), true, true); spl_autoload_register(array('ComposerAutoloaderInit927a7ea59f5590e9e57c74d6ecc97142', 'loadClassLoader'), true, true);
self::$loader = $loader = new \Composer\Autoload\ClassLoader(); self::$loader = $loader = new \Composer\Autoload\ClassLoader();
spl_autoload_unregister(array('ComposerAutoloaderInitdc48cac423beab724a7102138067b2f9', 'loadClassLoader')); spl_autoload_unregister(array('ComposerAutoloaderInit927a7ea59f5590e9e57c74d6ecc97142', 'loadClassLoader'));
$useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded()); $useStaticLoader = PHP_VERSION_ID >= 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded());
if ($useStaticLoader) { if ($useStaticLoader) {
require_once __DIR__ . '/autoload_static.php'; require_once __DIR__ . '/autoload_static.php';
call_user_func(\Composer\Autoload\ComposerStaticInitdc48cac423beab724a7102138067b2f9::getInitializer($loader)); call_user_func(\Composer\Autoload\ComposerStaticInit927a7ea59f5590e9e57c74d6ecc97142::getInitializer($loader));
} else { } else {
$map = require __DIR__ . '/autoload_namespaces.php'; $map = require __DIR__ . '/autoload_namespaces.php';
foreach ($map as $namespace => $path) { foreach ($map as $namespace => $path) {
@ -48,19 +48,19 @@ class ComposerAutoloaderInitdc48cac423beab724a7102138067b2f9
$loader->register(true); $loader->register(true);
if ($useStaticLoader) { if ($useStaticLoader) {
$includeFiles = Composer\Autoload\ComposerStaticInitdc48cac423beab724a7102138067b2f9::$files; $includeFiles = Composer\Autoload\ComposerStaticInit927a7ea59f5590e9e57c74d6ecc97142::$files;
} else { } else {
$includeFiles = require __DIR__ . '/autoload_files.php'; $includeFiles = require __DIR__ . '/autoload_files.php';
} }
foreach ($includeFiles as $fileIdentifier => $file) { foreach ($includeFiles as $fileIdentifier => $file) {
composerRequiredc48cac423beab724a7102138067b2f9($fileIdentifier, $file); composerRequire927a7ea59f5590e9e57c74d6ecc97142($fileIdentifier, $file);
} }
return $loader; return $loader;
} }
} }
function composerRequiredc48cac423beab724a7102138067b2f9($fileIdentifier, $file) function composerRequire927a7ea59f5590e9e57c74d6ecc97142($fileIdentifier, $file)
{ {
if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) { if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) {
require $file; require $file;

View File

@ -4,7 +4,7 @@
namespace Composer\Autoload; namespace Composer\Autoload;
class ComposerStaticInitdc48cac423beab724a7102138067b2f9 class ComposerStaticInit927a7ea59f5590e9e57c74d6ecc97142
{ {
public static $files = array ( public static $files = array (
'9b552a3cc426e3287cc811caefa3cf53' => __DIR__ . '/..' . '/topthink/think-helper/src/helper.php', '9b552a3cc426e3287cc811caefa3cf53' => __DIR__ . '/..' . '/topthink/think-helper/src/helper.php',
@ -470,9 +470,9 @@ class ComposerStaticInitdc48cac423beab724a7102138067b2f9
public static function getInitializer(ClassLoader $loader) public static function getInitializer(ClassLoader $loader)
{ {
return \Closure::bind(function () use ($loader) { return \Closure::bind(function () use ($loader) {
$loader->prefixLengthsPsr4 = ComposerStaticInitdc48cac423beab724a7102138067b2f9::$prefixLengthsPsr4; $loader->prefixLengthsPsr4 = ComposerStaticInit927a7ea59f5590e9e57c74d6ecc97142::$prefixLengthsPsr4;
$loader->prefixDirsPsr4 = ComposerStaticInitdc48cac423beab724a7102138067b2f9::$prefixDirsPsr4; $loader->prefixDirsPsr4 = ComposerStaticInit927a7ea59f5590e9e57c74d6ecc97142::$prefixDirsPsr4;
$loader->classMap = ComposerStaticInitdc48cac423beab724a7102138067b2f9::$classMap; $loader->classMap = ComposerStaticInit927a7ea59f5590e9e57c74d6ecc97142::$classMap;
}, null, ClassLoader::class); }, null, ClassLoader::class);
} }

View File

@ -608,17 +608,17 @@
}, },
{ {
"name": "topthink/think-orm", "name": "topthink/think-orm",
"version": "v2.0.27", "version": "v2.0.28",
"version_normalized": "2.0.27.0", "version_normalized": "2.0.28.0",
"source": { "source": {
"type": "git", "type": "git",
"url": "https://github.com/top-think/think-orm.git", "url": "https://github.com/top-think/think-orm.git",
"reference": "02affaaccade2cdd8bbb2d2f5d15e46113e6eb50" "reference": "ff5f112f5559497222f2716385b5a709ab82741b"
}, },
"dist": { "dist": {
"type": "zip", "type": "zip",
"url": "https://api.github.com/repos/top-think/think-orm/zipball/02affaaccade2cdd8bbb2d2f5d15e46113e6eb50", "url": "https://api.github.com/repos/top-think/think-orm/zipball/ff5f112f5559497222f2716385b5a709ab82741b",
"reference": "02affaaccade2cdd8bbb2d2f5d15e46113e6eb50", "reference": "ff5f112f5559497222f2716385b5a709ab82741b",
"shasum": "", "shasum": "",
"mirrors": [ "mirrors": [
{ {
@ -634,7 +634,7 @@
"psr/simple-cache": "^1.0", "psr/simple-cache": "^1.0",
"topthink/think-helper": "^3.1" "topthink/think-helper": "^3.1"
}, },
"time": "2019-10-23T02:16:50+00:00", "time": "2019-11-17T07:53:45+00:00",
"type": "library", "type": "library",
"installation-source": "dist", "installation-source": "dist",
"autoload": { "autoload": {
@ -805,12 +805,12 @@
"source": { "source": {
"type": "git", "type": "git",
"url": "https://github.com/zoujingli/ThinkLibrary.git", "url": "https://github.com/zoujingli/ThinkLibrary.git",
"reference": "9e636a7be3d7c468cb73c40c48835bf51cef6864" "reference": "bb5ec20e7047c582f1ae6e5faea7e3ecdf5a2da6"
}, },
"dist": { "dist": {
"type": "zip", "type": "zip",
"url": "https://api.github.com/repos/zoujingli/ThinkLibrary/zipball/9e636a7be3d7c468cb73c40c48835bf51cef6864", "url": "https://api.github.com/repos/zoujingli/ThinkLibrary/zipball/bb5ec20e7047c582f1ae6e5faea7e3ecdf5a2da6",
"reference": "9e636a7be3d7c468cb73c40c48835bf51cef6864", "reference": "bb5ec20e7047c582f1ae6e5faea7e3ecdf5a2da6",
"shasum": "", "shasum": "",
"mirrors": [ "mirrors": [
{ {
@ -826,7 +826,7 @@
"ext-json": "*", "ext-json": "*",
"topthink/framework": "^6.0" "topthink/framework": "^6.0"
}, },
"time": "2019-11-18T11:43:36+00:00", "time": "2019-11-19T02:13:00+00:00",
"type": "library", "type": "library",
"extra": { "extra": {
"think": { "think": {

2
vendor/services.php vendored
View File

@ -1,5 +1,5 @@
<?php <?php
// This file is automatically generated at:2019-11-18 19:45:16 // This file is automatically generated at:2019-11-19 10:15:33
declare (strict_types = 1); declare (strict_types = 1);
return array ( return array (
0 => 'think\\app\\Service', 0 => 'think\\app\\Service',

View File

@ -85,6 +85,12 @@ abstract class Model implements JsonSerializable, ArrayAccess, Arrayable, Jsonab
*/ */
protected $name; protected $name;
/**
* 主键值
* @var string
*/
protected $key;
/** /**
* 数据表名称 * 数据表名称
* @var string * @var string
@ -575,9 +581,13 @@ abstract class Model implements JsonSerializable, ArrayAccess, Arrayable, Jsonab
$db->startTrans(); $db->startTrans();
try { try {
$where = $this->getWhere(); $this->key = null;
$where = $this->getWhere();
$result = $db->where($where) $result = $db->where($where)
->strict(false) ->strict(false)
->cache(true)
->setOption('key', $this->key)
->field($allowFields) ->field($allowFields)
->update($data); ->update($data);
@ -635,14 +645,15 @@ abstract class Model implements JsonSerializable, ArrayAccess, Arrayable, Jsonab
$result = $db->strict(false) $result = $db->strict(false)
->field($allowFields) ->field($allowFields)
->replace($this->replace) ->replace($this->replace)
->insert($this->data, false, $sequence); ->sequence($sequence)
->insert($this->data, true);
// 获取自动增长主键 // 获取自动增长主键
if ($result && $insertId = $db->getLastInsID($sequence)) { if ($result) {
$pk = $this->getPk(); $pk = $this->getPk();
if (is_string($pk) && (!isset($this->data[$pk]) || '' == $this->data[$pk])) { if (is_string($pk) && (!isset($this->data[$pk]) || '' == $this->data[$pk])) {
$this->data[$pk] = $insertId; $this->data[$pk] = $result;
} }
} }
@ -676,7 +687,8 @@ abstract class Model implements JsonSerializable, ArrayAccess, Arrayable, Jsonab
$pk = $this->getPk(); $pk = $this->getPk();
if (is_string($pk) && isset($this->data[$pk])) { if (is_string($pk) && isset($this->data[$pk])) {
$where = [[$pk, '=', $this->data[$pk]]]; $where = [[$pk, '=', $this->data[$pk]]];
$this->key = $this->data[$pk];
} elseif (is_array($pk)) { } elseif (is_array($pk)) {
foreach ($pk as $field) { foreach ($pk as $field) {
if (isset($this->data[$field])) { if (isset($this->data[$field])) {

View File

@ -490,8 +490,8 @@ abstract class BaseQuery
// 子查询 // 子查询
} elseif (false === strpos($table, ',')) { } elseif (false === strpos($table, ',')) {
if (strpos($table, ' ')) { if (strpos($table, ' ')) {
list($item, $alias) = explode(' ', $table); [$item, $alias] = explode(' ', $table);
$table = []; $table = [];
$this->alias([$item => $alias]); $this->alias([$item => $alias]);
$table[$item] = $alias; $table[$item] = $alias;
} }
@ -502,7 +502,7 @@ abstract class BaseQuery
foreach ($tables as $item) { foreach ($tables as $item) {
$item = trim($item); $item = trim($item);
if (strpos($item, ' ')) { if (strpos($item, ' ')) {
list($item, $alias) = explode(' ', $item); [$item, $alias] = explode(' ', $item);
$this->alias([$item => $alias]); $this->alias([$item => $alias]);
$table[$item] = $alias; $table[$item] = $alias;
} else { } else {
@ -750,10 +750,10 @@ abstract class BaseQuery
* @access public * @access public
* @param mixed $key 缓存key * @param mixed $key 缓存key
* @param integer|\DateTime $expire 缓存有效期 * @param integer|\DateTime $expire 缓存有效期
* @param string $tag 缓存标签 * @param string|array $tag 缓存标签
* @return $this * @return $this
*/ */
public function cache($key = true, $expire = null, string $tag = null) public function cache($key = true, $expire = null, $tag = null)
{ {
if (false === $key || !$this->getConnection()->getCache()) { if (false === $key || !$this->getConnection()->getCache()) {
return $this; return $this;
@ -1179,11 +1179,11 @@ abstract class BaseQuery
if (isset($options['page'])) { if (isset($options['page'])) {
// 根据页数计算limit // 根据页数计算limit
list($page, $listRows) = $options['page']; [$page, $listRows] = $options['page'];
$page = $page > 0 ? $page : 1; $page = $page > 0 ? $page : 1;
$listRows = $listRows ?: (is_numeric($options['limit']) ? $options['limit'] : 20); $listRows = $listRows ?: (is_numeric($options['limit']) ? $options['limit'] : 20);
$offset = $listRows * ($page - 1); $offset = $listRows * ($page - 1);
$options['limit'] = $offset . ',' . $listRows; $options['limit'] = $offset . ',' . $listRows;
} }
$this->options = $options; $this->options = $options;

View File

@ -156,9 +156,9 @@ abstract class Builder
} }
if (false !== strpos($key, '->')) { if (false !== strpos($key, '->')) {
list($key, $name) = explode('->', $key, 2); [$key, $name] = explode('->', $key, 2);
$item = $this->parseKey($query, $key); $item = $this->parseKey($query, $key);
$result[$item] = 'json_set(' . $item . ', \'$.' . $name . '\', ' . $this->parseDataBind($query, $key . '->' . $name, $val, $bind) . ')'; $result[$item] = 'json_set(' . $item . ', \'$.' . $name . '\', ' . $this->parseDataBind($query, $key . '->' . $name, $val, $bind) . ')';
} elseif (false === strpos($key, '.') && !in_array($key, $fields, true)) { } elseif (false === strpos($key, '.') && !in_array($key, $fields, true)) {
if ($options['strict']) { if ($options['strict']) {
throw new Exception('fields not exists:[' . $key . ']'); throw new Exception('fields not exists:[' . $key . ']');
@ -300,7 +300,7 @@ abstract class Builder
if (!empty($options['soft_delete'])) { if (!empty($options['soft_delete'])) {
// 附加软删除条件 // 附加软删除条件
list($field, $condition) = $options['soft_delete']; [$field, $condition] = $options['soft_delete'];
$binds = $query->getFieldsBindType(); $binds = $query->getFieldsBindType();
$whereStr = $whereStr ? '( ' . $whereStr . ' ) AND ' : ''; $whereStr = $whereStr ? '( ' . $whereStr . ' ) AND ' : '';
@ -591,7 +591,7 @@ abstract class Builder
protected function parseColumn(Query $query, string $key, $exp, array $value, string $field, int $bindType): string protected function parseColumn(Query $query, string $key, $exp, array $value, string $field, int $bindType): string
{ {
// 字段比较查询 // 字段比较查询
list($op, $field) = $value; [$op, $field] = $value;
if (!in_array(trim($op), ['=', '<>', '>', '>=', '<', '<='])) { if (!in_array(trim($op), ['=', '<>', '>', '>=', '<', '<='])) {
throw new Exception('where express error:' . var_export($value, true)); throw new Exception('where express error:' . var_export($value, true));
@ -802,7 +802,7 @@ abstract class Builder
// 获取时间字段类型 // 获取时间字段类型
if (strpos($key, '.')) { if (strpos($key, '.')) {
list($table, $key) = explode('.', $key); [$table, $key] = explode('.', $key);
if (isset($options['alias']) && $pos = array_search($table, $options['alias'])) { if (isset($options['alias']) && $pos = array_search($table, $options['alias'])) {
$table = $pos; $table = $pos;
@ -858,10 +858,10 @@ abstract class Builder
$joinStr = ''; $joinStr = '';
foreach ($join as $item) { foreach ($join as $item) {
list($table, $type, $on) = $item; [$table, $type, $on] = $item;
if (strpos($on, '=')) { if (strpos($on, '=')) {
list($val1, $val2) = explode('=', $on, 2); [$val1, $val2] = explode('=', $on, 2);
$condition = $this->parseKey($query, $val1) . '=' . $this->parseKey($query, $val2); $condition = $this->parseKey($query, $val1) . '=' . $this->parseKey($query, $val2);
} else { } else {

View File

@ -96,7 +96,7 @@ class CacheItem
/** /**
* 获取缓存Tag * 获取缓存Tag
* @access public * @access public
* @return string * @return string|array
*/ */
public function getTag() public function getTag()
{ {
@ -139,10 +139,10 @@ class CacheItem
/** /**
* 为此缓存项设置所属标签 * 为此缓存项设置所属标签
* @access public * @access public
* @param string $tag * @param string|array $tag
* @return $this * @return $this
*/ */
public function tag(string $tag = null) public function tag($tag = null)
{ {
$this->tag = $tag; $this->tag = $tag;
return $this; return $this;

View File

@ -236,7 +236,7 @@ abstract class Connection
*/ */
protected function parseCache(BaseQuery $query, array $cache): CacheItem protected function parseCache(BaseQuery $query, array $cache): CacheItem
{ {
list($key, $expire, $tag) = $cache; [$key, $expire, $tag] = $cache;
if ($key instanceof CacheItem) { if ($key instanceof CacheItem) {
$cacheItem = $key; $cacheItem = $key;

View File

@ -303,7 +303,7 @@ class Fetch
if (!empty($options['soft_delete'])) { if (!empty($options['soft_delete'])) {
// 软删除 // 软删除
list($field, $condition) = $options['soft_delete']; [$field, $condition] = $options['soft_delete'];
if ($condition) { if ($condition) {
$this->query->setOption('soft_delete', null); $this->query->setOption('soft_delete', null);
$this->query->setOption('data', [$field => $condition]); $this->query->setOption('data', [$field => $condition]);

View File

@ -615,7 +615,7 @@ class Mongo extends BaseQuery
$query = $this->options($options)->limit($count); $query = $this->options($options)->limit($count);
if (strpos($column, '.')) { if (strpos($column, '.')) {
list($alias, $key) = explode('.', $column); [$alias, $key] = explode('.', $column);
} else { } else {
$key = $column; $key = $column;
} }
@ -712,4 +712,30 @@ class Mongo extends BaseQuery
return $options; return $options;
} }
/**
* 获取字段类型信息
* @access public
* @return array
*/
public function getFieldsType(): array
{
if (!empty($this->options['field_type'])) {
return $this->options['field_type'];
}
return [];
}
/**
* 获取字段类型信息
* @access public
* @param string $field 字段名
* @return string|null
*/
public function getFieldType(string $field)
{
$fieldType = $this->getFieldsType();
return $fieldType[$field] ?? null;
}
} }

View File

@ -98,6 +98,12 @@ abstract class PDOConnection extends Connection implements ConnectionInterface
*/ */
protected $transTimes = 0; protected $transTimes = 0;
/**
* 重连次数
* @var int
*/
protected $reConnectTimes = 0;
/** /**
* 查询结果类型 * 查询结果类型
* @var int * @var int
@ -329,7 +335,7 @@ abstract class PDOConnection extends Connection implements ConnectionInterface
return []; return [];
} }
list($tableName) = explode(' ', $tableName); [$tableName] = explode(' ', $tableName);
if (!strpos($tableName, '.')) { if (!strpos($tableName, '.')) {
$schema = $this->getConfig('database') . '.' . $tableName; $schema = $this->getConfig('database') . '.' . $tableName;
@ -703,9 +709,12 @@ abstract class PDOConnection extends Connection implements ConnectionInterface
$this->trigger('', $master); $this->trigger('', $master);
} }
$this->reConnectTimes = 0;
return $this->PDOStatement; return $this->PDOStatement;
} catch (\Throwable | \Exception $e) { } catch (\Throwable | \Exception $e) {
if ($this->isBreak($e)) { if ($this->reConnectTimes < 4 && $this->isBreak($e)) {
++$this->reConnectTimes;
return $this->close()->getPDOStatement($sql, $bind, $master, $procedure); return $this->close()->getPDOStatement($sql, $bind, $master, $procedure);
} }
@ -1070,7 +1079,7 @@ abstract class PDOConnection extends Connection implements ConnectionInterface
public function aggregate(BaseQuery $query, string $aggregate, $field, bool $force = false) public function aggregate(BaseQuery $query, string $aggregate, $field, bool $force = false)
{ {
if (is_string($field) && 0 === stripos($field, 'DISTINCT ')) { if (is_string($field) && 0 === stripos($field, 'DISTINCT ')) {
list($distinct, $field) = explode(' ', $field); [$distinct, $field] = explode(' ', $field);
} }
$field = $aggregate . '(' . (!empty($distinct) ? 'DISTINCT ' : '') . $this->builder->parseKey($query, $field, true) . ') AS think_' . strtolower($aggregate); $field = $aggregate . '(' . (!empty($distinct) ? 'DISTINCT ' : '') . $this->builder->parseKey($query, $field, true) . ') AS think_' . strtolower($aggregate);
@ -1141,11 +1150,11 @@ abstract class PDOConnection extends Connection implements ConnectionInterface
if (strpos($column, ',')) { if (strpos($column, ',')) {
$column = null; $column = null;
} elseif (strpos($column, '.')) { } elseif (strpos($column, '.')) {
list($alias, $column) = explode('.', $column); [$alias, $column] = explode('.', $column);
} }
if (strpos($key, '.')) { if (strpos($key, '.')) {
list($alias, $key) = explode('.', $key); [$alias, $key] = explode('.', $key);
} }
$result = array_column($resultSet, $column, $key); $result = array_column($resultSet, $column, $key);
@ -1348,9 +1357,11 @@ abstract class PDOConnection extends Connection implements ConnectionInterface
$this->parseSavepoint('trans' . $this->transTimes) $this->parseSavepoint('trans' . $this->transTimes)
); );
} }
$this->reConnectTimes = 0;
} catch (\Exception $e) { } catch (\Exception $e) {
if ($this->isBreak($e)) { if ($this->reConnectTimes < 4 && $this->isBreak($e)) {
--$this->transTimes; --$this->transTimes;
++$this->reConnectTimes;
$this->close()->startTrans(); $this->close()->startTrans();
} }
throw $e; throw $e;

View File

@ -460,7 +460,7 @@ class Query extends BaseQuery
$query = $this->options($options)->limit($count); $query = $this->options($options)->limit($count);
if (strpos($column, '.')) { if (strpos($column, '.')) {
list($alias, $key) = explode('.', $column); [$alias, $key] = explode('.', $column);
} else { } else {
$key = $column; $key = $column;
} }

View File

@ -58,7 +58,7 @@ class Mongo
protected function parseKey(Query $query, string $key): string protected function parseKey(Query $query, string $key): string
{ {
if (0 === strpos($key, '__TABLE__.')) { if (0 === strpos($key, '__TABLE__.')) {
list($collection, $key) = explode('.', $key, 2); [$collection, $key] = explode('.', $key, 2);
} }
if ('id' == $key && $this->connection->getConfig('pk_convert_id')) { if ('id' == $key && $this->connection->getConfig('pk_convert_id')) {
@ -205,8 +205,8 @@ class Mongo
$options = $query->getOptions(); $options = $query->getOptions();
if (!empty($options['soft_delete'])) { if (!empty($options['soft_delete'])) {
// 附加软删除条件 // 附加软删除条件
list($field, $condition) = $options['soft_delete']; [$field, $condition] = $options['soft_delete'];
$filter['$and'][] = $this->parseWhereItem($query, $field, $condition); $filter['$and'][] = $this->parseWhereItem($query, $field, $condition);
} }
return $filter; return $filter;
@ -220,7 +220,7 @@ class Mongo
if (!is_array($val)) { if (!is_array($val)) {
$val = ['=', $val]; $val = ['=', $val];
} }
list($exp, $value) = $val; [$exp, $value] = $val;
// 对一个字段使用多个查询条件 // 对一个字段使用多个查询条件
if (is_array($exp)) { if (is_array($exp)) {
@ -523,8 +523,8 @@ class Mongo
*/ */
public function aggregate(Query $query, array $extra): Command public function aggregate(Query $query, array $extra): Command
{ {
$options = $query->getOptions(); $options = $query->getOptions();
list($fun, $field) = $extra; [$fun, $field] = $extra;
if ('id' == $field && $this->connection->getConfig('pk_convert_id')) { if ('id' == $field && $this->connection->getConfig('pk_convert_id')) {
$field = '_id'; $field = '_id';
@ -568,7 +568,7 @@ class Mongo
{ {
$options = $query->getOptions(); $options = $query->getOptions();
list($aggregate, $groupBy) = $extra; [$aggregate, $groupBy] = $extra;
$groups = ['_id' => []]; $groups = ['_id' => []];

View File

@ -315,10 +315,10 @@ class Mysql extends Builder
if (strpos($key, '->') && false === strpos($key, '(')) { if (strpos($key, '->') && false === strpos($key, '(')) {
// JSON字段支持 // JSON字段支持
list($field, $name) = explode('->', $key, 2); [$field, $name] = explode('->', $key, 2);
return 'json_extract(' . $this->parseKey($query, $field) . ', \'$' . (strpos($name, '[') === 0 ? '' : '.') . str_replace('->', '.', $name) . '\')'; return 'json_extract(' . $this->parseKey($query, $field) . ', \'$' . (strpos($name, '[') === 0 ? '' : '.') . str_replace('->', '.', $name) . '\')';
} elseif (strpos($key, '.') && !preg_match('/[,\'\"\(\)`\s]/', $key)) { } elseif (strpos($key, '.') && !preg_match('/[,\'\"\(\)`\s]/', $key)) {
list($table, $key) = explode('.', $key, 2); [$table, $key] = explode('.', $key, 2);
$alias = $query->getOptions('alias'); $alias = $query->getOptions('alias');

View File

@ -75,8 +75,8 @@ class Oracle extends Builder
if (strpos($key, '->') && false === strpos($key, '(')) { if (strpos($key, '->') && false === strpos($key, '(')) {
// JSON字段支持 // JSON字段支持
list($field, $name) = explode($key, '->'); [$field, $name] = explode($key, '->');
$key = $field . '."' . $name . '"'; $key = $field . '."' . $name . '"';
} }
return $key; return $key;

View File

@ -76,10 +76,10 @@ class Pgsql extends Builder
if (strpos($key, '->') && false === strpos($key, '(')) { if (strpos($key, '->') && false === strpos($key, '(')) {
// JSON字段支持 // JSON字段支持
list($field, $name) = explode('->', $key); [$field, $name] = explode('->', $key);
$key = '"' . $field . '"' . '->>\'' . $name . '\''; $key = '"' . $field . '"' . '->>\'' . $name . '\'';
} elseif (strpos($key, '.')) { } elseif (strpos($key, '.')) {
list($table, $key) = explode('.', $key, 2); [$table, $key] = explode('.', $key, 2);
$alias = $query->getOptions('alias'); $alias = $query->getOptions('alias');

View File

@ -74,7 +74,7 @@ class Sqlite extends Builder
$key = trim($key); $key = trim($key);
if (strpos($key, '.')) { if (strpos($key, '.')) {
list($table, $key) = explode('.', $key, 2); [$table, $key] = explode('.', $key, 2);
$alias = $query->getOptions('alias'); $alias = $query->getOptions('alias');

View File

@ -78,7 +78,7 @@ class Sqlsrv extends Builder
$array[] = $this->parseRand($query); $array[] = $this->parseRand($query);
} else { } else {
if (is_numeric($key)) { if (is_numeric($key)) {
list($key, $sort) = explode(' ', strpos($val, ' ') ? $val : $val . ' '); [$key, $sort] = explode(' ', strpos($val, ' ') ? $val : $val . ' ');
} else { } else {
$sort = $val; $sort = $val;
} }
@ -121,7 +121,7 @@ class Sqlsrv extends Builder
$key = trim($key); $key = trim($key);
if (strpos($key, '.') && !preg_match('/[,\'\"\(\)\[\s]/', $key)) { if (strpos($key, '.') && !preg_match('/[,\'\"\(\)\[\s]/', $key)) {
list($table, $key) = explode('.', $key, 2); [$table, $key] = explode('.', $key, 2);
$alias = $query->getOptions('alias'); $alias = $query->getOptions('alias');

View File

@ -109,7 +109,7 @@ trait JoinAndViewQuery
// 使用别名 // 使用别名
if (strpos($join, ' ')) { if (strpos($join, ' ')) {
// 使用别名 // 使用别名
list($table, $alias) = explode(' ', $join); [$table, $alias] = explode(' ', $join);
} else { } else {
$table = $join; $table = $join;
if (false === strpos($join, '.')) { if (false === strpos($join, '.')) {
@ -209,7 +209,7 @@ trait JoinAndViewQuery
foreach ($options['order'] as $key => $val) { foreach ($options['order'] as $key => $val) {
if (is_numeric($key) && is_string($val)) { if (is_numeric($key) && is_string($val)) {
if (strpos($val, ' ')) { if (strpos($val, ' ')) {
list($field, $sort) = explode(' ', $val); [$field, $sort] = explode(' ', $val);
if (array_key_exists($field, $options['map'])) { if (array_key_exists($field, $options['map'])) {
$options['order'][$options['map'][$field]] = $sort; $options['order'][$options['map'][$field]] = $sort;
unset($options['order'][$key]); unset($options['order'][$key]);

View File

@ -414,7 +414,7 @@ trait ModelRelationQuery
if (!empty($this->options['with_attr'])) { if (!empty($this->options['with_attr'])) {
foreach ($this->options['with_attr'] as $name => $val) { foreach ($this->options['with_attr'] as $name => $val) {
if (strpos($name, '.')) { if (strpos($name, '.')) {
list($relation, $field) = explode('.', $name); [$relation, $field] = explode('.', $name);
$withRelationAttr[$relation][$field] = $val; $withRelationAttr[$relation][$field] = $val;
unset($this->options['with_attr'][$name]); unset($this->options['with_attr'][$name]);
@ -458,7 +458,7 @@ trait ModelRelationQuery
if (!empty($options['with_attr']) && empty($withRelationAttr)) { if (!empty($options['with_attr']) && empty($withRelationAttr)) {
foreach ($options['with_attr'] as $name => $val) { foreach ($options['with_attr'] as $name => $val) {
if (strpos($name, '.')) { if (strpos($name, '.')) {
list($relation, $field) = explode('.', $name); [$relation, $field] = explode('.', $name);
$withRelationAttr[$relation][$field] = $val; $withRelationAttr[$relation][$field] = $val;
unset($options['with_attr'][$name]); unset($options['with_attr'][$name]);

View File

@ -130,7 +130,7 @@ trait ResultOperation
if (strpos($name, '.')) { if (strpos($name, '.')) {
// 支持JSON字段 获取器定义 // 支持JSON字段 获取器定义
list($key, $field) = explode('.', $name); [$key, $field] = explode('.', $name);
if (isset($result[$key])) { if (isset($result[$key])) {
$result[$key][$field] = $closure($result[$key][$field] ?? null, $result[$key]); $result[$key][$field] = $closure($result[$key][$field] ?? null, $result[$key]);

View File

@ -1011,6 +1011,17 @@ class Mongo extends Connection implements ConnectionInterface
return $this->command($command, $db); return $this->command($command, $db);
} }
/**
* 获取数据库字段
* @access public
* @param mixed $tableName 数据表名
* @return array
*/
public function getTableFields($tableName): array
{
return [];
}
/** /**
* 执行数据库事务 * 执行数据库事务

View File

@ -53,7 +53,7 @@ class Mysql extends PDOConnection
*/ */
public function getFields(string $tableName): array public function getFields(string $tableName): array
{ {
list($tableName) = explode(' ', $tableName); [$tableName] = explode(' ', $tableName);
if (false === strpos($tableName, '`')) { if (false === strpos($tableName, '`')) {
if (strpos($tableName, '.')) { if (strpos($tableName, '.')) {

View File

@ -50,8 +50,8 @@ class Oracle extends PDOConnection
*/ */
public function getFields(string $tableName): array public function getFields(string $tableName): array
{ {
list($tableName) = explode(' ', $tableName); [$tableName] = explode(' ', $tableName);
$sql = "select a.column_name,data_type,DECODE (nullable, 'Y', 0, 1) notnull,data_default, DECODE (A .column_name,b.column_name,1,0) pk from all_tab_columns a,(select column_name from all_constraints c, all_cons_columns col where c.constraint_name = col.constraint_name and c.constraint_type = 'P' and c.table_name = '" . strtoupper($tableName) . "' ) b where table_name = '" . strtoupper($tableName) . "' and a.column_name = b.column_name (+)"; $sql = "select a.column_name,data_type,DECODE (nullable, 'Y', 0, 1) notnull,data_default, DECODE (A .column_name,b.column_name,1,0) pk from all_tab_columns a,(select column_name from all_constraints c, all_cons_columns col where c.constraint_name = col.constraint_name and c.constraint_type = 'P' and c.table_name = '" . strtoupper($tableName) . "' ) b where table_name = '" . strtoupper($tableName) . "' and a.column_name = b.column_name (+)";
$pdo = $this->getPDOStatement($sql); $pdo = $this->getPDOStatement($sql);
$result = $pdo->fetchAll(PDO::FETCH_ASSOC); $result = $pdo->fetchAll(PDO::FETCH_ASSOC);

View File

@ -56,8 +56,8 @@ class Pgsql extends PDOConnection
*/ */
public function getFields(string $tableName): array public function getFields(string $tableName): array
{ {
list($tableName) = explode(' ', $tableName); [$tableName] = explode(' ', $tableName);
$sql = 'select fields_name as "field",fields_type as "type",fields_not_null as "null",fields_key_name as "key",fields_default as "default",fields_default as "extra" from table_msg(\'' . $tableName . '\');'; $sql = 'select fields_name as "field",fields_type as "type",fields_not_null as "null",fields_key_name as "key",fields_default as "default",fields_default as "extra" from table_msg(\'' . $tableName . '\');';
$pdo = $this->getPDOStatement($sql); $pdo = $this->getPDOStatement($sql);
$result = $pdo->fetchAll(PDO::FETCH_ASSOC); $result = $pdo->fetchAll(PDO::FETCH_ASSOC);

View File

@ -41,8 +41,8 @@ class Sqlite extends PDOConnection
*/ */
public function getFields(string $tableName): array public function getFields(string $tableName): array
{ {
list($tableName) = explode(' ', $tableName); [$tableName] = explode(' ', $tableName);
$sql = 'PRAGMA table_info( ' . $tableName . ' )'; $sql = 'PRAGMA table_info( ' . $tableName . ' )';
$pdo = $this->getPDOStatement($sql); $pdo = $this->getPDOStatement($sql);
$result = $pdo->fetchAll(PDO::FETCH_ASSOC); $result = $pdo->fetchAll(PDO::FETCH_ASSOC);

View File

@ -55,7 +55,7 @@ class Sqlsrv extends PDOConnection
*/ */
public function getFields(string $tableName): array public function getFields(string $tableName): array
{ {
list($tableName) = explode(' ', $tableName); [$tableName] = explode(' ', $tableName);
$sql = "SELECT column_name, data_type, column_default, is_nullable $sql = "SELECT column_name, data_type, column_default, is_nullable
FROM information_schema.tables AS t FROM information_schema.tables AS t

View File

@ -398,9 +398,9 @@ trait Attribute
} }
if (is_array($type)) { if (is_array($type)) {
list($type, $param) = $type; [$type, $param] = $type;
} elseif (strpos($type, ':')) { } elseif (strpos($type, ':')) {
list($type, $param) = explode(':', $type, 2); [$type, $param] = explode(':', $type, 2);
} }
switch ($type) { switch ($type) {
@ -563,9 +563,9 @@ trait Attribute
} }
if (is_array($type)) { if (is_array($type)) {
list($type, $param) = $type; [$type, $param] = $type;
} elseif (strpos($type, ':')) { } elseif (strpos($type, ':')) {
list($type, $param) = explode(':', $type, 2); [$type, $param] = explode(':', $type, 2);
} }
switch ($type) { switch ($type) {
@ -637,7 +637,7 @@ trait Attribute
$name = $this->getRealFieldName($name); $name = $this->getRealFieldName($name);
if (strpos($name, '.')) { if (strpos($name, '.')) {
list($name, $key) = explode('.', $name); [$name, $key] = explode('.', $name);
$this->withAttr[$name][$key] = $callback; $this->withAttr[$name][$key] = $callback;
} else { } else {

View File

@ -132,7 +132,7 @@ trait Conversion
foreach ($this->visible as $key => $val) { foreach ($this->visible as $key => $val) {
if (is_string($val)) { if (is_string($val)) {
if (strpos($val, '.')) { if (strpos($val, '.')) {
list($relation, $name) = explode('.', $val); [$relation, $name] = explode('.', $val);
$this->visible[$relation][] = $name; $this->visible[$relation][] = $name;
} else { } else {
$this->visible[$val] = true; $this->visible[$val] = true;
@ -145,7 +145,7 @@ trait Conversion
foreach ($this->hidden as $key => $val) { foreach ($this->hidden as $key => $val) {
if (is_string($val)) { if (is_string($val)) {
if (strpos($val, '.')) { if (strpos($val, '.')) {
list($relation, $name) = explode('.', $val); [$relation, $name] = explode('.', $val);
$this->hidden[$relation][] = $name; $this->hidden[$relation][] = $name;
} else { } else {
$this->hidden[$val] = true; $this->hidden[$val] = true;
@ -192,7 +192,7 @@ trait Conversion
$item[$key] = $relation ? $relation->append($name) $item[$key] = $relation ? $relation->append($name)
->toArray() : []; ->toArray() : [];
} elseif (strpos($name, '.')) { } elseif (strpos($name, '.')) {
list($key, $attr) = explode('.', $name); [$key, $attr] = explode('.', $name);
// 追加关联对象属性 // 追加关联对象属性
$relation = $this->getRelation($key, true); $relation = $this->getRelation($key, true);
$item[$key] = $relation ? $relation->append([$attr]) $item[$key] = $relation ? $relation->append([$attr])

View File

@ -148,7 +148,7 @@ trait RelationShip
$subRelation = $relation; $subRelation = $relation;
$relation = $key; $relation = $key;
} elseif (strpos($relation, '.')) { } elseif (strpos($relation, '.')) {
list($relation, $subRelation) = explode('.', $relation, 2); [$relation, $subRelation] = explode('.', $relation, 2);
} }
$method = Str::camel($relation); $method = Str::camel($relation);
@ -263,7 +263,7 @@ trait RelationShip
$subRelation = $relation; $subRelation = $relation;
$relation = $key; $relation = $key;
} elseif (strpos($relation, '.')) { } elseif (strpos($relation, '.')) {
list($relation, $subRelation) = explode('.', $relation, 2); [$relation, $subRelation] = explode('.', $relation, 2);
$subRelation = [$subRelation]; $subRelation = [$subRelation];
} }
@ -312,7 +312,7 @@ trait RelationShip
$subRelation = $relation; $subRelation = $relation;
$relation = $key; $relation = $key;
} elseif (strpos($relation, '.')) { } elseif (strpos($relation, '.')) {
list($relation, $subRelation) = explode('.', $relation, 2); [$relation, $subRelation] = explode('.', $relation, 2);
$subRelation = [$subRelation]; $subRelation = [$subRelation];
} }
@ -549,7 +549,7 @@ trait RelationShip
} }
if (is_array($morph)) { if (is_array($morph)) {
list($morphType, $foreignKey) = $morph; [$morphType, $foreignKey] = $morph;
} else { } else {
$morphType = $morph . '_type'; $morphType = $morph . '_type';
$foreignKey = $morph . '_id'; $foreignKey = $morph . '_id';
@ -581,7 +581,7 @@ trait RelationShip
$type = $type ?: get_class($this); $type = $type ?: get_class($this);
if (is_array($morph)) { if (is_array($morph)) {
list($morphType, $foreignKey) = $morph; [$morphType, $foreignKey] = $morph;
} else { } else {
$morphType = $morph . '_type'; $morphType = $morph . '_type';
$foreignKey = $morph . '_id'; $foreignKey = $morph . '_id';
@ -608,7 +608,7 @@ trait RelationShip
// 记录当前关联信息 // 记录当前关联信息
if (is_array($morph)) { if (is_array($morph)) {
list($morphType, $foreignKey) = $morph; [$morphType, $foreignKey] = $morph;
} else { } else {
$morphType = $morph . '_type'; $morphType = $morph . '_type';
$foreignKey = $morph . '_id'; $foreignKey = $morph . '_id';

View File

@ -133,7 +133,7 @@ class BelongsToMany extends Relation
foreach ($model->getData() as $key => $val) { foreach ($model->getData() as $key => $val) {
if (strpos($key, '__')) { if (strpos($key, '__')) {
list($name, $attr) = explode('__', $key, 2); [$name, $attr] = explode('__', $key, 2);
if ('pivot' == $name) { if ('pivot' == $name) {
$pivot[$attr] = $val; $pivot[$attr] = $val;
@ -206,12 +206,11 @@ class BelongsToMany extends Relation
* @access public * @access public
* @param int|array $listRows * @param int|array $listRows
* @param int|bool $simple * @param int|bool $simple
* @param array $config
* @return Paginator * @return Paginator
*/ */
public function paginate($listRows = null, $simple = false, $config = []): Paginator public function paginate($listRows = null, $simple = false): Paginator
{ {
$result = $this->buildQuery()->paginate($listRows, $simple, $config); $result = $this->buildQuery()->paginate($listRows, $simple);
$this->hydratePivot($result); $this->hydratePivot($result);
return $result; return $result;
@ -448,7 +447,7 @@ class BelongsToMany extends Relation
$pivot = []; $pivot = [];
foreach ($set->getData() as $key => $val) { foreach ($set->getData() as $key => $val) {
if (strpos($key, '__')) { if (strpos($key, '__')) {
list($name, $attr) = explode('__', $key, 2); [$name, $attr] = explode('__', $key, 2);
if ('pivot' == $name) { if ('pivot' == $name) {
$pivot[$attr] = $val; $pivot[$attr] = $val;
unset($set->$key); unset($set->$key);

View File

@ -234,7 +234,7 @@ abstract class OneToOne extends Relation
// 重新组装模型数据 // 重新组装模型数据
foreach ($result->getData() as $key => $val) { foreach ($result->getData() as $key => $val) {
if (strpos($key, '__')) { if (strpos($key, '__')) {
list($name, $attr) = explode('__', $key, 2); [$name, $attr] = explode('__', $key, 2);
if ($name == $relation) { if ($name == $relation) {
$list[$name][$attr] = $val; $list[$name][$attr] = $val;
unset($result->$key); unset($result->$key);

View File

@ -70,7 +70,7 @@ abstract class Helper
* @param array $args 额外参数 * @param array $args 额外参数
* @return static * @return static
*/ */
public static function instance($args = []) public static function instance(array $args = [])
{ {
return Container::getInstance()->invokeClass(static::class, $args); return Container::getInstance()->invokeClass(static::class, $args);
} }

View File

@ -28,32 +28,21 @@ use think\Service;
class Library extends Service class Library extends Service
{ {
/** /**
* 服务注册 * 注册服务
*/ */
public function register() public function register()
{ {
// 注册会话中间键 if (PHP_SAPI !== 'cli') {
$this->app->middleware->add(SessionInit::class); // 注册会话中间键
// 动态加入应用函数 $this->app->middleware->add(SessionInit::class);
foreach (glob($this->app->getAppPath() . '*/sys.php') as $file) { // 注册访问中间键
\Composer\Autoload\includeFile($file);
}
}
/**
* 服务启动
*/
public function boot()
{
// 注册访问中间键
if (!$this->app->request->isCli()) {
$this->app->middleware->add(function (Request $request, \Closure $next) { $this->app->middleware->add(function (Request $request, \Closure $next) {
$header = []; $header = [];
if (($origin = $request->header('origin', '*')) !== '*') { if (($origin = $request->header('origin', '*')) !== '*') {
$header['Access-Control-Allow-Origin'] = $origin; $header['Access-Control-Allow-Origin'] = $origin;
$header['Access-Control-Allow-Methods'] = 'GET,POST,PATCH,PUT,DELETE'; $header['Access-Control-Allow-Methods'] = 'GET,POST,PATCH,PUT,DELETE';
$header['Access-Control-Allow-Headers'] = 'Authorization,Content-Type,If-Match,If-Modified-Since,If-None-Match,If-Unmodified-Since,X-Requested-With'; $header['Access-Control-Allow-Headers'] = 'Authorization,Content-Type,If-Match,If-Modified-Since,If-None-Match,If-Unmodified-Since,X-Requested-With';
$header['Access-Control-Expose-Headers'] = 'User-Form-Token'; $header['Access-Control-Expose-Headers'] = 'User-Form-Token,User-Token,Token';
} }
// 访问模式及访问权限检查 // 访问模式及访问权限检查
if ($request->isOptions()) { if ($request->isOptions()) {
@ -67,6 +56,17 @@ class Library extends Service
} }
}, 'route'); }, 'route');
} }
// 动态加入应用函数
foreach (glob($this->app->getAppPath() . '*/sys.php') as $file) {
\Composer\Autoload\includeFile($file);
}
}
/**
* 启动服务
*/
public function boot()
{
// 注册系统任务指令 // 注册系统任务指令
$this->commands([ $this->commands([
'think\admin\queue\WorkQueue', 'think\admin\queue\WorkQueue',
@ -78,5 +78,4 @@ class Library extends Service
'think\admin\command\Install', 'think\admin\command\Install',
]); ]);
} }
} }

View File

@ -64,7 +64,7 @@ class Install extends Command
protected function configure() protected function configure()
{ {
$this->setName('xtask:install'); $this->setName('xtask:install');
$this->setDescription("[安装]在线安装或更新指定模块文件"); $this->setDescription("[安装]安装或更新指定模块");
$this->addArgument('name', Argument::OPTIONAL, '模块名称', ''); $this->addArgument('name', Argument::OPTIONAL, '模块名称', '');
} }

View File

@ -32,7 +32,7 @@ class ListenQueue extends Command
*/ */
protected function configure() protected function configure()
{ {
$this->setName('xtask:listen')->setDescription('[监听]常驻异步任务循环监听主进程'); $this->setName('xtask:listen')->setDescription('[监听]启动任务监听主进程');
} }
/** /**
@ -46,10 +46,10 @@ class ListenQueue extends Command
protected function execute(Input $input, Output $output) protected function execute(Input $input, Output $output)
{ {
$this->app->db->name('SystemQueue')->count(); $this->app->db->name('SystemQueue')->count();
if (($process = ProcessService::instance($this->app))->iswin()) { if (($process = ProcessService::instance())->iswin()) {
$this->setProcessTitle("ThinkAdmin 监听主进程 {$process->version()}"); $this->setProcessTitle("ThinkAdmin 监听主进程 {$process->version()}");
} }
$output->comment('============ 异步任务监听中 ============'); $output->comment('============ 任务监听中 ============');
while (true) { while (true) {
foreach ($this->app->db->name('SystemQueue')->where([['status', '=', '1'], ['exec_time', '<=', time()]])->order('exec_time asc')->limit(100)->select() as $vo) { foreach ($this->app->db->name('SystemQueue')->where([['status', '=', '1'], ['exec_time', '<=', time()]])->order('exec_time asc')->limit(100)->select() as $vo) {
try { try {

View File

@ -32,7 +32,7 @@ class QueryQueue extends Command
*/ */
protected function configure() protected function configure()
{ {
$this->setName('xtask:query')->setDescription('[控制]查询正在执行的所有任务进程'); $this->setName('xtask:query')->setDescription('[控制]查询正在运行的进程');
} }
/** /**

View File

@ -21,7 +21,7 @@ use think\console\Input;
use think\console\Output; use think\console\Output;
/** /**
* 检查并创建异步任务监听主进程 * 检查并创建监听主进程
* Class StartQueue * Class StartQueue
* @package think\admin\queue * @package think\admin\queue
*/ */
@ -33,7 +33,7 @@ class StartQueue extends Command
*/ */
protected function configure() protected function configure()
{ {
$this->setName('xtask:start')->setDescription('[控制]创建异步任务守护监听主进程'); $this->setName('xtask:start')->setDescription('[控制]创建守护监听主进程');
} }
/** /**
@ -47,14 +47,14 @@ class StartQueue extends Command
$process = ProcessService::instance(); $process = ProcessService::instance();
$command = $process->think("xtask:listen"); $command = $process->think("xtask:listen");
if (count($result = $process->query($command)) > 0) { if (count($result = $process->query($command)) > 0) {
$output->info("异步任务监听主进程{$result['0']['pid']}已经启动!"); $output->info("监听主进程{$result['0']['pid']}已经启动!");
} else { } else {
$process->create($command); $process->create($command);
sleep(1); sleep(1);
if (count($result = $process->query($command)) > 0) { if (count($result = $process->query($command)) > 0) {
$output->info("异步任务监听主进程{$result['0']['pid']}启动成功!"); $output->info("监听主进程{$result['0']['pid']}启动成功!");
} else { } else {
$output->error('异步任务监听主进程创建失败!'); $output->error('监听主进程创建失败!');
} }
} }
} }

View File

@ -32,7 +32,7 @@ class StateQueue extends Command
*/ */
protected function configure() protected function configure()
{ {
$this->setName('xtask:state')->setDescription('[控制]查看异步任务监听主进程状态'); $this->setName('xtask:state')->setDescription('[控制]查看监听主进程状态');
} }
/** /**

View File

@ -33,7 +33,7 @@ class StopQueue extends Command
*/ */
protected function configure() protected function configure()
{ {
$this->setName('xtask:stop')->setDescription('[控制]平滑停止所有的异步任务进程'); $this->setName('xtask:stop')->setDescription('[控制]平滑停止所有的进程');
} }
/** /**

View File

@ -48,7 +48,7 @@ class WorkQueue extends Command
*/ */
protected function configure() protected function configure()
{ {
$this->setName('xtask:_work')->setDescription('[执行]创建执行单个指定任务的进程'); $this->setName('xtask:_work')->setDescription('[执行]创建指令任务的进程');
$this->addArgument('code', Argument::OPTIONAL, '任务编号'); $this->addArgument('code', Argument::OPTIONAL, '任务编号');
$this->addArgument('splt', Argument::OPTIONAL, '指令结束符'); $this->addArgument('splt', Argument::OPTIONAL, '指令结束符');
} }