### 2018 年 11 月 25 日 发布 经过20天的改进和测试,ThinkPHP5.2第二个`Beta`测试版本发布了。这次主要改进了`fetchSql`方法的处理机制,统一和简化了很多查询用法。(安装和基本使用请[参考这里](https://blog.thinkphp.cn/826584)) ## 主要更新 ### 改进了fetchSql的解析机制 引入了单独的`Fetch`类单独处理`fetchSql`方法,确保`Query`类查询方法的返回类型不受`fetchSql`影响。 ### 统一和精简了查询用法 本次测试版本统一和精简了很多查询用法,让你不会再有一个查询功能多种用法的困扰,便于制定团队规范。 * `get`/`all`查询方法统一为`find`/`select`方法; * 取消`fetchPdo`方法,返回PDO对象统一使用`pdo`查询方法; * 废弃`resultset_type`配置统一使用`fetchCollection`方法; * 取消`readMaster`方法,统一使用`master`方法; * 模型`save`方法不支持传入条件,统一查询和更新方法调用; * 取消`db`/`model`助手函数,统一使用类调用; ### 增加了`fetchArray`方法 如果使用了模型查询,现在可以通过调用`fetchArray`方法,查询结果将始终返回数组数据。方便一些统计图表的数据传入。 ### 时间字段写入改用`DateTime`类 时间字段的自动操作改用`DateTime`类,支持微秒级时间记录,提供更高精度的系统时间记录。 只需要设置数据表时间字段的小数位精度即可自动记录,如果需要输出微秒精度数据,设置`dateTimeFormat`格式即可。 ### 模型增加`schema`属性 模型增加`schema`属性支持,用于定义对应数据表的字段及类型信息,并且支持使用PHP变量类型定义。定义了该属性后,无需使用`optimize:schema`即可提升查询性能,以及自动识别字段的参数绑定类型。 模型的`type`属性仅用于设置自动类型转换的数据表字段。 ### 支持应用公共函数文件 多应用模式下,支持加载应用的公共函数文件。 ### 多入口文件自动识别 如果没有在应用入口文件中指定应用名,入口文件访问的时候可以自动识别当前的应用名称。默认会取当前应用入口的文件名作为应用名。 ### 部分方法不再支持 以下用法出于实用性或精简考虑不再支持: * `Query`类的`fetchPdo`方法(可以使用`pdo`方法替代); * `Query`类的`get`/`all`/`getOrFail`/`allOrFail`方法; * 模型类的`save`方法不再支持`where`参数; * `Query`类和模型类的`readMaster`方法,该方法在`swoole`下无法正常使用(需要的话手动调用`master`方法); * 模型类的`setInc`和`setDec`方法; * 数据库的`resultset_type`设置 (需要的话调用`fetchCollection`方法); * `db`助手函数(使用`Db`类静态方法替代); ## 更新日志 * 改进`join`方法的`table`参数解析 * 废弃save方法的`where`参数 * 取消模型类的`setInc`和`setDec`方法 * 改进模型字段信息的获取 * 取消模型和Db类的`readMaster`方法 * 改进参数绑定类型获取 * Query类增加`fetchArray`方法 支持模型查询返回数组类型 * 时间字段自动写入改为使用`DateTime`类,支持微秒数据 * 改进验证类 扩展验证规则的时候不检查是否require * 改进查询CURD方法 * 修正模型输出 * 改进`update`方法 * 修正`insertGetId`方法 * 修正`getFieldType`方法 * 改进`think schema` 指令 * 改进缓存和日志的路径获取 * 删除`db`助手函数 修正几个助手函数 * Builder类`select`方法增加第二个参数 * 取消`resultset_type`设置 * 修正动态查询方法的`fetchsql`处理 * 改进多应用入口文件的自动识别 * 修正server方法的返回类型 * 多应用模式允许加载公共函数文件 * 修正路由类`getBind`方法 * 改进`session`配置参数 * 修正资源路由 * 改进`console`类 * 修正`make`指令 * 改进控制器`assign`方法 * 修正`Cookie`类 * 修正`request`类 * 修正`console`调试驱动 * 取消Query类的`get`/`all`方法 统一使用`find`/`select`方法 * 取消`fetchPdo`方法 * 修正`insertall`的`limit`参数 * 改进严格模式下的错误 * 改进`fetchSql`方法 增加`Fetch`对象