文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

mysql管理系统操作日志设计举例分析

2024-04-02 19:55

关注

本篇内容介绍了“mysql管理系统操作日志设计举例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

在开始做之前,必须把两个日志分清楚,那就是普通操作日志和业务操作日志,这两者有何区别?

在我理解,普通操作日志就是单表的操作记录,而业务操作日志则就是一系列的普通操作日志的集合。

打个比方,用户需要购买一样宝贝,已经到了下单那步,下单就是个业务,这个业务背后就是一系列的业务,如:生成订单 → 生成商品快照 → 发送一条站内信 → 删除购物车里对应宝贝。

这样一个下单操作就包含了4部分,可以把这4部分看成是4张表,分别对这4张表进行对应的操作,就实现了业务。

但今天我要讲的不是业务操作日志,因为不同项目的业务不尽相同,所以它无法做成通用模块,而我要讲的,就是普通操作日志。

上面解释了一大段,下面干货就要亮相了,先洗把脸清醒下。

首先,哪些地方需要记录操作日志?执行insert、update、delete这3个操作的时候,就需要进行日志,而日志执行的先后顺序如下

mysql管理系统操作日志设计举例分析

顺序清楚后,就来看下我写的一份日志操作类吧,***版随便谢谢的,重复代码有点多,还未来得及优化。

class LOG{      protected $primaryid;      protected $tbid;      protected $tbname;      protected $keys;      protected $values;           public function insert($tbid, $tbname){          global $db;          //查询表注释          $db->query('show table status where name = "'.$tbname.'"');          $tb = $db->fetch();          //插入日志主表          $returnid = $db->insert(0, 2, 'tb_log', array(              'adminid = '.$_SESSION['admin']['id'],              'type = 1',              'tableid = '.$tbid,              'tablename = "'.$tbname.'"',              'comment = "'.$tb['Comment'].'"',              'dt = now()'         ));          //查询字段注释          $db->query('show full columns from '.$tbname);          $tb = $db->fetchAll();          foreach($tb as $v){              $commentArray[$v['Field']] = $v['Comment'];          }          //查询所有字段信息,插入日志从表          $rs = $db->select(0, 1, $tbname, '*', 'and tbid = '.$tbid);          $keys = array_keys($rs);          $values = array_values($rs);          for($i = 0; $i < count($keys); $i++){              $db->insert(0, 0, 'tb_log_content', array(                  'logid = '.$returnid,                  'tbkey = "'.$keys[$i].'"',                  'tbvalue = "'.$values[$i].'"',                  'comment = "'.$commentArray[$keys[$i]].'"'             ));          }      }      public function updateStart($tbid, $tbname){          global $db;          //查询表注释          $db->query('show table status where name = "'.$tbname.'"');          $tb = $db->fetch();          //插入日志主表          $returnid = $db->insert(0, 2, 'tb_log', array(              'adminid = '.$_SESSION['admin']['id'],              'type = 2',              'tableid = '.$tbid,              'tablename = "'.$tbname.'"',              'comment = "'.$tb['Comment'].'"',              'dt = now()'         ));          //查询修改前数据信息          $rs = $db->select(0, 1, $tbname, '*', 'and tbid = '.$tbid);          $keys = array_keys($rs);          $values = array_values($rs);          $this->primaryid = $returnid;          $this->tbid = $tbid;          $this->tbname = $tbname;          $this->keys = $keys;          $this->values = $values;      }      public function updateEnd(){          global $db;          //查询字段注释          $db->query('show full columns from '.$this->tbname);          $tb = $db->fetchAll();          foreach($tb as $v){              $commentArray[$v['Field']] = $v['Comment'];          }          //查询修改后数据信息          $rs = $db->select(0, 1, $this->tbname, '*', 'and tbid = '.$this->tbid);          $currentvalues = array_values($rs);          //前后信息进行比较          for($i = 0; $i < count($currentvalues); $i++){              if($this->values[$i] !== $currentvalues[$i]){                  $db->insert(0, 0, 'tb_log_content', array(                      'logid = '.$this->primaryid,                      'tbkey = "'.$this->keys[$i].'"',                      'tbvalue = "'.$this->values[$i].'"',                      'currenttbvalue = "'.$currentvalues[$i].'"',                      'comment = "'.$commentArray[$this->keys[$i]].'"'                 ));              }          }      }      public function delete($tbid, $tbname){          global $db;          //查询表注释          $db->query('show table status where name = "'.$tbname.'"');          $tb = $db->fetch();          //插入日志主表          $returnid = $db->insert(0, 2, 'tb_log', array(              'adminid = '.$_SESSION['admin']['id'],              'type = 3',              'tableid = '.$tbid,              'tablename = "'.$tbname.'"',              'comment = "'.$tb['Comment'].'"',              'dt = now()'         ));          //查询字段注释          $db->query('show full columns from '.$tbname);          $tb = $db->fetchAll();          foreach($tb as $v){              $commentArray[$v['Field']] = $v['Comment'];          }          //查询所有字段信息,插入日志从表          $rs = $db->select(0, 1, $tbname, '*', 'and tbid = '.$tbid);          $keys = array_keys($rs);          $values = array_values($rs);          for($i = 0; $i < count($keys); $i++){              $db->insert(0, 0, 'tb_log_content', array(                  'logid = '.$returnid,                  'tbkey = "'.$keys[$i].'"',                  'tbvalue = "'.$values[$i].'"',                  'comment = "'.$commentArray[$keys[$i]].'"'             ));          }      }  }

引入之后,就可以开始使用了。

select

$log->insert(82, 'tb_member');

update

$log->updateStart(82, 'tb_member');   //中间放更新操作代码   $log->updateEnd();

delete

$log->delete(82, 'tb_member');

可以看到,一共只需要两个参数即可,分别是表ID(主键)和表名称。

另外需要强调一点,表注释和字段注释一定要完整,因为记录的信息包含注释,目的就是为了查阅的时候能清楚哪个字段是干什么用的。

下面就看下成品吧

mysql管理系统操作日志设计举例分析

mysql管理系统操作日志设计举例分析

“mysql管理系统操作日志设计举例分析”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯