ThinkPHP执行调用存储过程怎么添加日志//PHP代码部分/**

* [LogAdd 操作日志]

* @param [string] $userid [用户的ID]

* @param [string] $type [类型]

* @param [string] $controller_name [当前控制器的中文名称]

* @param [string] $function_name [当前方法的中文名称]

*/function LogAdd($userid,$type,$controller_name,$function_name){

//组合数据

$data['userid'] = $userid;//当前操作的用户

$data['type'] = $type;//当前操作的类型

$data['url'] = 'http://'.$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];//当前操作的URL地址

$data['controller'] = CONTROLLER_NAME;//当前控制器的名称

$data['controller_name'] = $controller_name;//当前控制器的中文名称

$data['function'] = ACTION_NAME;//当前方法的名称

$data['function_name'] = $function_name;//当前方法的中文名称

$data['ip'] = getClientIP();//IP地址

$data['create_time'] = date('Y-m-d H:i:s',time());//登录时间

//表名

$data_fun = 't_sys_logs_'.date('Y',time());

//执行原生SQL

$Model = M();

$results = $Model->query('show tables');//打开库

//组装为一维数组进行判断

foreach($results as $k=>$v){

$data_table_show[] = $v['tables_in_dbwxapplite'];

}

//先判断是否存在表

if(in_array(strtolower($data_fun), $data_table_show)){

//存在表直接添加日志

$loginLog = M($data_fun)->add($data);

if($loginLog != false){

$res = ['status' => '1','result' => '写入成功','data' => $loginLog];

}else{

$res = ['status' => '0','result' => '写入失败','data' => $loginLog];

}

}else{

//不存在表,先调用存储过程,在执行添加日志

$code = $Model->query("call spCreateTableSysLogs(".date('Y',time()).")");

if($code){

//存储过程成功则添加数据

$loginLog = M($data_fun)->add($data);

if($loginLog != false){

$res = ['status' => '1','result' => '写入成功','data' => $loginLog];

}else{

$res = ['status' => '0','result' => '写入失败','data' => $loginLog];

}

}else{

//失败

$res = ['status' => '0','result' => '存储过程调用失败','data' => $loginLog];

}

}

return $res;}//mysql脚本数据库部分-- ------------------------------ Table structure for t_sys_logs_2017-- ----------------------------DROP TABLE IF EXISTS `t_sys_logs_2017`;CREATE TABLE `t_sys_logs_2017` (

`logid` int(11) NOT NULL AUTO_INCREMENT COMMENT '日志ID',

`userid` varchar(32) NOT NULL DEFAULT '0' COMMENT '创建人ID',

`type` varchar(8) NOT NULL COMMENT '日志操作类型,如:登录;注销;退出;修改密码;创建报名',

`url` varchar(100) NOT NULL DEFAULT 'www' COMMENT '当前操作的URL',

`controller` varchar(30) NOT NULL DEFAULT '控制器的名称' COMMENT '当前控制器的名称',

`controller_name` varchar(30) NOT NULL DEFAULT '控制器的中文名称' COMMENT '当前控制器的中文名称',

`function` varchar(30) NOT NULL DEFAULT '方法的名称' COMMENT '当前方法的名称',

`function_name` varchar(30) NOT NULL DEFAULT '方法的中文名称' COMMENT '当前方法的中文名称',

`ip` varchar(30) NOT NULL DEFAULT '255.255.255.255' COMMENT '当前操作客户端IP',

`create_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' COMMENT '创建时间',

`update_time` timestamp NOT NULL DEFAULT '0000-00-00 00:00:00' ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',

PRIMARY KEY (`logid`)) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COMMENT='操作日志表';

thinkphp调用mysql存储过程_ThinkPHP执行调用存储过程怎么添加日志相关推荐

  1. Mysql SQL语句执行更新或者插入添加条件判断

    Mysql SQL语句执行更新或者插入添加条件判断 – 更新操作 – INSERT INTO materials (ID,Name,Remaining,Total) VALUES (1,'SolidW ...

  2. ibatis调用mysql带OUT类型参数的存储过程并获取返回值

    存储过程的参数: P_SAVEOBJ( IN I_ID_OBJ INT, IN STR_OBJNAME VARCHAR(255), OUT o_ret VARCHAR(100) ) xml配置: &l ...

  3. pdo mysql 存储过程 out_PHP_PDO 调用mysql 带返回参数的存储过程

    DROP PROCEDURE IF EXISTS pro_test; create procedure pro_test(in val VARCHAR(50) ,out rtn int) begin ...

  4. mysql查询正在执行的存储过程,[转]ms sql server 存储过程,查看正在执行的sql语句...

    简介  大家都知道使用sp_who2这个命令来查看当前正在的执行的SQL语句的spids.但是显示 的信息有限.比如,它只显示执行SELECT,DELETE,UPDATE等.看不到实际的sql命令. ...

  5. mysql plugin 调用_MySQL插件接口的调用方式

    author:sufei 版本:8.0.16 一.简介 首先简单说明一下插件的实现原理 在程序的合适位置(挂钩处)安插相应的函数指针,相应的结构类似:if (fun_ptr != null) fun_ ...

  6. mysql存储过程执行两边_麻烦问下,为什么我的mysql存储过程一次调用,会被执行了两次?...

    你的位置: 问答吧 -> MySQL -> 问题详情 麻烦问下,为什么我的mysql存储过程一次调用,会被执行了两次? mysql版本是 mysql-community-5.1.45 系统 ...

  7. MySQL 学习笔记(6)— 存储过程创建、调用、删除以及带参数的存储过程

    1. 存储过程总结 存储过程是一种存储在数据库中的程序.它可以包含多个 SQL 语句,并提供许多过程语言的功能,例如变量定义.条件控制语句.循环语句.游标以及异常处理等. 1.1 存储过程优点 实现代 ...

  8. hibernate mysql 存储过程_hibernate调用mysql存储过程

    hibernate调用mysql存储过程 在最近的项目中,碰到一小段数据库数据分析的程序,需要结合多张表联合查询或涉及到子查询,项目主要采用的java ee开发,使用了hibernate框架,由于这些 ...

  9. mysql jdbc 创建存储过程_mysql JDBC 调用存储过程

    与oracle不同,mysql不支持匿名块,如果需要写过程语句,则必需定义存储过程.如果你会oracle的存储过程,那么mysql的存储过程也很简单了. 一.创建存储过程 create procedu ...

最新文章

  1. kd tree python 搜索
  2. 路由怎么定位到当前页面的组件_Angular 重载当前路由
  3. python跟java 效率_Python和Java该如何选择?老男孩Python人工智能
  4. android自动化框架简要剖析(一):运行原理+基本框架
  5. 这个教程价值有点高,利用Python制作全自动化营销软件!
  6. 几行代码构建全功能对象检测模型,这位杜克大学学生做到了!
  7. java 向后台传两个json数据类型_前台向后台传递JSON字符串,处理JSON字符串类型的方法...
  8. fckeditor for java_FCKeditor最新版本2.4.1 for java 教程
  9. 计算机组成原理习题答案(蒋本珊)
  10. Windows 95/98虚拟机OS安装说明书[仅限VirtualBox]
  11. 创建新的apple id_新的Apple Maps与Google Maps:哪个适合您?
  12. 信安小组 第三周 总结
  13. 风变python基础语法_风变编程python (基础语法爬虫精进)
  14. SwiftUI macOS 轻松搭建音乐Radio类App界面(教程含源码)
  15. ln -s 命令详解
  16. 华为手机自带邮箱如何添加新浪邮箱账号
  17. how2j学习笔记(JAVA中级)
  18. Windows10系统修改桌面图标间距的方法介绍
  19. IntelliJ IDEA设置查看Java API帮助文档
  20. Smart Share:抓住每一个机会,让数据释放无限可能

热门文章

  1. 物理实验模拟软件_网络系统实验平台:发展现状及展望
  2. panel垂直滚动条占用宽度_南开区垂直车库门车库门安装价格
  3. mysql invalid default value_mysql5.x升级到5.7 导入数据出错,提示Invalid default value for...
  4. OpenShift 4 之Service Mesh教程(4)- 跟踪访问后端服务超时
  5. (四)训练运行Deep CycleGAN以进行移动风格迁移
  6. Gitee 上线多项 PR 功能优化,进一步提升审查与提交效率
  7. 为什么新技术产品经常出问题,以及如何在您的公司中防止它
  8. 在.NET单元测试中使用嵌入式资源
  9. 微软开源软件特征源码分析工具 Application Inspector
  10. WHERE和HAVING子句有什么区别?