# 模型基类之常用数据处理方法
[TOC]
## 模型中的showReturnCode
~~~
static public function showReturnCode($code = '', $data = [], $msg = ''){
return \app\base\controller\Base::showReturnCode($code, $data, $msg);
}
static public function showReturnCodeWithOutData($code = '', $msg = '')
{
return \app\base\controller\Base::showReturnCode($code, [], $msg);
}
~~~
## 模型中的editData 很老的代码的 懒得改了 凑合用吧
使用方法详见
https://www.kancloud.cn/mikkle/thinkphp5_study/334906
~~~
/**
* 根据有Id修改信息 无Id 新增信息
* #User: Mikkle
* #Email:776329498@qq.com
* #Date:
* @param $data
* @return false|int|string
* @throws
*/
public function editData($data){
if (isset($data['id'])){
if (is_numeric($data['id']) && $data['id']>0){
$save = $this->allowField(true)->save($data,[ 'id' => $data['id']]);
}else{
$save = $this->allowField(true)->save($data);
}
}else{
$save = $this->allowField(true)->save($data);
}
if ( $save == 0 || $save == false) {
$res=[ 'code'=> 1009, 'msg' => '数据更新失败', ];
}else{
$res=[ 'code'=> 1001, 'msg' => '数据更新成功', ];
}
return $res;
}
~~~
## 创建个性GUID
~~~
/**
* 创建个性GUID
* Power by Mikkle
* QQ:776329498
* @param string $base_code
* @return string
*/
public function create_uuid($base_code = '')
{
if (empty($base_code)) {
$base_name = basename(str_replace('\\', '/', get_called_class()), '.php');
$uuid_list = ModelCode::$uuid_list;
$base_code = isset($uuid_list[$base_name]) ? $uuid_list[$base_name] : 'QT';
}
$uuid = $base_code . strtoupper(uniqid()) . $this->builderRand(6);
return $uuid;
}
~~~
>[info] ModelCode::$uuid_list;中定义了个性前缀
这个代码写的比较早了 ,其实 $base_name =$this->name 就能获取到
![](https://box.kancloud.cn/f60da94f764f6fc4c3cb0a1e37339389_381x455.png)
## 创建随机数
~~~
/**
* 创建随机数
* Power by Mikkle
* QQ:776329498
* @param int $num 随机数位数
* @return string
*/
public function builderRand($num=8){
return substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, $num);
}
~~~
## 通过查询条件获取单条数据对象
~~~
/**
* 通过查询条件获取单条数据对象
* Power: Mikkle
* Email:776329498@qq.com
* @param array $map 查询条件
* @param bool|true $field 字段
* @param array $append 追加已经定义获取器字段
* @param bool|true $status
* @return $this|array|false|\PDOStatement|string|Model
*/
public function getInfoByMap($map=[],$field=true,$append=[],$status=true){
if($status&&!isset($map['status'])){
$map['status']=1;
}
$object = $this->where($map)->field($field)->find();
if(!empty($object)&&!empty($append)){
return $object->append($append);
}else{
return $object;
}
}
~~~
## 通过查询条件获取单条数据(数组)
~~~
/**
* 通过查询条件获取单条数据(数组)
* User: Mikkle
* Q Q:776329498
* @param array $map
* @param bool|true $field
* @param array $append
* @param bool|true $status
* @return array
*/
public function getArrayByMap($map=[],$field=true,$append=[],$status=true){
if($status&&!isset($map['status'])){
$map['status']=1;
}
$object = $this->where($map)->field($field)->find();
if(!empty($object)&&!empty($append)){
$return = $object->append($append);
}else{
$return = $object;
}
return empty($return) ? [] : $return->toArray();
}
~~~
## 通过查询条件获取多条数据(数组)
~~~
/**
* Power: Mikkle
* Email:776329498@qq.com
* @param array $map
* @param bool|true $field
* @param array $append 这需要在模型里增加获取器
* @param bool|true $status
* @return array
*/
public function getListByMap($map=[],$field=true,$append=[],$status=true){
if($status&&!isset($map['status'])){
$map['status']=1;
}
$object_list = $this->where($map)->field($field)->select();
$list=[];
if(!empty($object_list)){
foreach($object_list as $item=>$value){
if(!empty($append)){
$list[]= $value->append($append)->toArray();
}else{
$list[]= $value->toArray();
}
}
}
return $list;
}
~~~
## 有乐观锁的快速修改
使用方法
https://www.kancloud.cn/mikkle/thinkphp5_study/359349
~~~
/**
* 带有乐观锁的修改
* Power: Mikkle
* Email:776329498@qq.com
* @param $save_data 修改的数据
* @param string $edit_pk 修改的ID字段名称
* @param string $version_field 乐观锁版本号字段名称
* @return array
*/
public function editDateWithLock($save_data,$edit_pk="",$version_field=""){
if (empty($version_field)){
$version_field = isset($this->versionField) ? $this->versionField : "edit_version";
}
if (empty($edit_pk)){
$edit_pk = isset($this->editPk) ? $this->editPk : $this->getPk();
}
//判断PK字段是否存在
if (!isset($save_data[$edit_pk])||!isset($save_data[$version_field])){
return self::showReturnCodeWithOutData(1003,"参数缺失");
}else{
//设置升级检索条件 PK和版本号
$map[$edit_pk] = $save_data[$edit_pk];
$map[$version_field] = $save_data[$version_field];
//剔除PK
unset($save_data[$edit_pk]);
}
try{
//检测版本字段
if($this->hasColumn($version_field)){
throw new Exception("乐观锁版本字段[$version_field]不存在");
}
$original_data = $this->where($map)->find();
if (empty($original_data)){
throw new Exception("此条信息已经变动了,请重新操作!");
}
foreach ($save_data as $item=>$value){
if (isset($original_data[$item])){
//修改的数值不变时候 剔除
if ($original_data[$item]==$value){
unset( $save_data[$item]);
}elseif($item!=$version_field){
unset( $original_data[$item]);
}
}else{
//修改的字段不存在 剔除
unset( $save_data[$item]);
}
}
if(empty($save_data)){
throw new Exception("修改的数值无变化");
}
//版本号升级
$save_data[$version_field]=(int)$original_data[$version_field]+1;
if (1!=$this->allowField(true)->save($save_data,$map)){
throw new Exception("修改信息出错:".$this->getError());
}
//记录修改日志
$this->saveEditLog($original_data,$save_data);
return self::showReturnCodeWithOutData(1001);
}catch (Exception $e){
$msg=$e->getMessage();
return self::showReturnCodeWithOutData(1003,$msg);
}
}
~~~
## 判断字段是否存在
~~~
/**
* 判断字段是否存在
* Power: Mikkle
* Email:776329498@qq.com
* @param $column
* @param string $table
* @return bool
*/
protected function hasColumn($column,$table=""){
$table = isset($table)?$table:$this->table;
if (empty($table)||$column){
$this->error="hasColumn方法参数缺失";
return false;
}
$sql = "SELECT * FROM information_schema.columns WHERE table_schema=CurrentDatabase AND table_name = '{$table}' AND column_name = '{$column}'";
return $this->query($sql) ? true : false;
}
~~~
- 序言及更新日志
- 前言一 开发PHP必备的环境(你可以不看)
- LinUX系统ThinkPHP5链接MsSQL数据库的pdo_dblib扩展
- centos7.2挂载硬盘攻略
- Centos系统Redis安装及Redis的PHP扩展安装
- Centos系统增加Swap(系统交换区)的方法
- 前言二 开发PHP软件配置和介绍(你依然可以不看)
- 数据库SQL文件
- 本地Git(版本控制)的搭建
- GIT远程仓库的克隆和推送
- Git常用命令
- PHP面向对象思想实战经验领悟
- PHP面向对象实战----命名空间
- PHP面向对象实战----继承
- 基类实战--底层方法封装
- 基类实战--构造函数实战
- 基类实战--析构函数的使用
- TP5实战开发前篇---控制器(controller)
- 控制器中Request类的使用
- 控制器中基类的使用
- TP5实战开发前篇---模型篇(model)
- TP5实战开发前篇---验证器篇(Validate)
- TP5实战课程入门篇---花拳绣腿
- 模块以及类的文件的建立
- Api开发------单条信息显示
- Api开发---单条信息复杂关联显示
- Api开发---查询信息缓存Cache的应用
- TP5实战技巧---开发思路 引路造桥
- TP5实战技巧---整合基类 化繁为简
- TP5实战课程入门篇---数据操作
- Api开发---数据的添加和修改
- API开发---快速开发API通用接口
- TP5专用微信sdk使用教程
- THINKPHP5微信SDK更新记录及升级指导
- TP5专用SDK 微信参数配置方法
- 微信公众号推送接口对接教程
- 微信推送接口对接示例含扫描登录微信端部分
- TP5专用微信支付SDK使用简介
- TP5专用支付宝支付SDK使用说明
- 使用NW将开发的网站打包成桌面应用
- TP5高阶实战课程 进阶篇概述
- 进阶篇一 实战开发之习惯及要求
- 进阶篇二 实战开发之控制器
- 控制器基类之控制器基类使用方法
- 控制器基类之控制器基类常用方法分享
- 控制器基类之构造函数的使用方法
- 进阶篇三 实战开发之权限控制
- TP5实战源码 --- 全局用户信息验证类Auth
- TP5实战源码 --- 微信Auth实战开发源码
- 进阶篇四 实战开发之模型
- 模型基类之模型基类的用途
- 模型基类之常用数据处理方法
- 模型逻辑层之实战代码(含事务)
- 模型实战开发之模型常用方法
- 模型实战源码 --- 乐观锁的应用
- 模型实战技巧---Model事件功能的使用
- 模型事件实战应用---数据库操作日志
- 进阶篇五 实战开发之缓存(Cache)
- TP5实战源码---应用缓存获取城市信息
- TP5实战源码---应用缓存获取分类详情
- 进阶篇六 TP5类库的封装和使用
- DataEdit快捷操作类库
- ShowCode快捷使用类库
- 阿里大于 短信API接口 TP5专用类库
- DatabaseUpgrade数据库对比及更新类库
- AuthWeb权限类使用说明
- 进阶篇七 服务层的应用
- 服务层源码示例
- 服务层基类源码
- 进阶篇八 应用层Redis数据处理基类
- Redis服务层基类源码
- 进阶篇九 使用Redis类库处理一般的抢购(秒杀)活动示例
- 进阶篇十 某大型项目应用本Redis类源码示例(含事务 乐观锁)
- 进阶篇十一 逻辑层的应用
- 逻辑层基类源码
- 进阶篇 服务层代码示例
- 高阶实战课程 进阶篇持续新增中
- 高阶篇一 TP5命令行之守护任务源码
- TP5实战源码 --- 命令行
- TP5实战源码 --- 通过shell建立PHP守护程序
- 高阶篇二 使用Redis队列发送微信模版消息
- 高阶篇二 之 Worker队列基类源码
- 高阶篇三 TP5实战之Redis缓存应用
- Redis实战源码之Hash专用类库源码
- Redis实战源码之Model类结合
- Redis实战源码之模型Hash基类源码
- Redis实战源码之Hash查询使用技巧
- Redis实战源码之 shell脚本中redis赋值和取值
- 高阶篇四 Swoole的实战应用
- swoole基类代码
- Swoole扩展WebsocketServer专用类
- 基于Swoole的多Room聊天室的程序
- Swoole守护服务shell源码
- 高阶篇五 命令行异步多进程队列类的应用
- tp_worker类源码
- WorkerBase
- WorkerCommand
- WorkerRedis
- Redis类
- CycleWorkBase
- WorkerHookBase异步钩子
- 队列日志SQL
- 高阶篇六 定时执行队列类库以及使用方法
- 定时队列类库源码
- 高阶篇七 异步执行循环队列类库以及使用教程
- CycleWorkBase源码
- 高阶实战课程 进阶篇持续新增中
- Extend便捷类库源码库
- 阿里相关类库
- SendSms--验证码API接口文件
- 权限相关类库目录
- AuthWeb 权限验证类库
- Redis便捷操作类库(20171224更新)
- Redis
- Tools工具类库集
- Curl类库
- DataEdit
- Rand类库
- ShowCode类库
- Upload类库
- 附件集合
- 附件一:微信支付 实战开发源码
- 微信支付类库源代码
- Common_util_pub.php
- DownloadBill_pub.php
- JsApi_pub.php
- NativeCall_pub.php
- NativeLink_pub.php
- OrderQuery_pub.php
- Refund_pub.php
- RefundQuery_pub.php
- SDKRuntimeException.php
- ShortUrl_pub.php
- UnifiedOrder_pub.php
- Wxpay_client_pub.php
- Wxpay_server_pub.php
- WxPayConf_pub.php
- 微信支付回调页面源码
- 附件二 顺丰快递BSP接口实战开发源码
- 顺丰快递BSP接口实战开发源码
- 顺丰BSP基类
- 顺丰BSP基础代码
- 顺丰BSP下单接口
- 顺丰BSP查单接口
- 顺丰BSP确认/取消接口
- 附件三 APP注册登陆接口源码(含融云平台接口)
- 附件四 TP5订单Model(含事务 获取器 修改器等方法)
- 附录五 RSA加密解密
- Rsa文件源码
- 附件六 阿里大于短信接口
- 附件七 AES加解密类
- AES加解密类源码
- 附件八 TP5路由设置源码
- 附件九 TP5 Excel导入导出下载便捷类库
- Excel类库TP5源码
- 附件十 TP5便捷操作Redis类库源码
- TP5源码 Redis操作便捷类库
- 附件十一 TP5源码 上传文件入库类源码
- 上传类Upload源码
- Upload类上传配置文件
- 存储图像文件的数据库SQL文件
- 存储文件的数据库SQL文件
- 附件十二 TP5 图片处理增强类 支持缩略图在线显示
- 附件十三 微信推送消息接口类库源码
- 附件十三 微信推送消息接口类库源码 之 基类
- 附件十四 存储微信昵称的处理方法