ThinkPHP实现转换数据库查询结果数据到对应类型的方法
2017-11-16 10:55
1066 查看
本文实例讲述了ThinkPHP实现转换数据库查询结果数据到对应类型的方法。分享给大家供大家参考,具体如下:
最近使用 ThinkPHP3.2.3 进行 API 开发,发现 ThinkPHP3.x 查询数据库返回所有字段值类型都是 String。以前开发 web 的时候没怎么注意这个,现在发现用到 API 开发很难办,数据类型不对,不能每个字段都让客户端自己强制转换一下。
查资料后发现 ThinkPHP3.x 的 Model.class.php,提供了 _parseType 方法,在查询完以后进行类型转换,但需要我们手工调一下。
需要自己写一个 Model 基类:
MBaseModel.class.php 继承自 Model
use Think\Model; class BaseModel extends Model { protected function _after_select(&$resultSet, $options) { parent::_after_select($resultSet,$options); foreach ($resultSet as &$result) { $this->_after_find($result, $options); } } protected function _after_find(&$result, $options) { parent::_after_find($result,$options); foreach ($result as $field => $value) { $this->_parseType($result, $field); } } }
然后所有自己写的 Model 类都继承自 MBaseModel.
注意:必须把上面两个方法写到 Model 的子类中。
本来,这样已经搞定了,但发现 Model.class.php 的 _parseType 方法里有个低级 bug:
/** * 数据类型检测 * @access protected * @param mixed $data 数据 * @param string $key 字段名 * @return void */ protected function _parseType(&$data,$key) { if(!isset($this->options['bind'][':'.$key]) && isset($this->fields['_type'][$key])){ $fieldType = strtolower($this->fields['_type'][$key]); if(false !== strpos($fieldType,'enum')){ // 支持ENUM类型优先检测 }elseif(false === strpos($fieldType,'bigint') && false !== strpos($fieldType,'int')) { $data[$key] = intval($data[$key]); }elseif(false !== strpos($fieldType,'float') || false !== strpos($fieldType,'double')){ $data[$key] = floatval($data[$key]); }elseif(false !== strpos($fieldType,'bool')){ $data[$key] = (bool)$data[$key]; } } } // 上面第13行修改为 }elseif(false !== strpos($fieldType,'bigint') || false !== strpos($fieldType,'int') || false !== strpos($fieldType,'tinyint')) {
更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《thinkPHP模板操作技巧总结》、《ThinkPHP常用方法总结》、《codeigniter入门教程》、《CI(CodeIgniter)框架进阶教程》、《Zend FrameWork框架入门教程》及《PHP模板技术总结》。
希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。
您可能感兴趣的文章:
相关文章推荐
- SQL C# nvarchar类型转换为int类型 多表查询的问题,查询结果到新表,TXT数据读取到控件和数据库,生成在控件中的数据如何存到TXT文件中
- 主流数据库之间对SQL:2003标准的不同实现方法比较(第四部分 查询结果集中间n行数据)
- MySQL中数据结果集分页功能的实现方法;数据库查询返回特定结果即分页查询
- WPF中在XAML中实现数据类型转换的两种方法
- 从数据库查询出来的数据集合转换成 json 类型
- 连接数据库及数据查询的简单实现方法
- 大津阈值OSTU函数实现方法对比, Mat转换为IplImage 类型,并复制数据
- PHP查询并删除数据库多列重复数据的方法(利用数组函数实现)
- ThinkPHP5查询数据及处理结果的方法小结
- ThinkPHP 中 M 方法查询数据库最后使用 find() 导致返回结果集 foreach 数据不对的问题
- 在Mybaties中进行数据查询时,表中字段名和属相名没有对应起来,查询的结果总null,一下是解决方法
- PHP查询并删除数据库多列重复数据的方法(利用数组函数实现)
- 查询数据库中的表,返回字段相对应的数据类型!
- thinkPHP5实现的查询数据库并返回json数据实例
- 根据反射将数据库查询结果Datatable,转换为对应的Model类实体对象
- 用ObjectDataProvider绑定方法,用IValueConverter实现数据类型转换,重载ValidationRule实现数据验证,BindsDirectlyToSource等
- 报错:对象必须实现 IConvertible;以分隔符进行分割链接concat_ws的使用方法;mysql数据类型转换cast,convert
- GP数据库笔记--数据类型转换,杀掉进程的方法
- json格式数据 ,将数据库中查询的结果转换为json(方式2)
- 主流数据库之间对SQL:2003标准的不同实现方法比较(第六部分 基础数据类型之BOOLEAN)