溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

mysql管理系統(tǒng)操作日志設(shè)計(jì)舉例分析

發(fā)布時(shí)間:2021-11-18 11:23:01 來源:億速云 閱讀:156 作者:iii 欄目:web開發(fā)

本篇內(nèi)容介紹了“mysql管理系統(tǒng)操作日志設(shè)計(jì)舉例分析”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

在開始做之前,必須把兩個(gè)日志分清楚,那就是普通操作日志和業(yè)務(wù)操作日志,這兩者有何區(qū)別?

在我理解,普通操作日志就是單表的操作記錄,而業(yè)務(wù)操作日志則就是一系列的普通操作日志的集合。

打個(gè)比方,用戶需要購買一樣寶貝,已經(jīng)到了下單那步,下單就是個(gè)業(yè)務(wù),這個(gè)業(yè)務(wù)背后就是一系列的業(yè)務(wù),如:生成訂單 → 生成商品快照 → 發(fā)送一條站內(nèi)信 → 刪除購物車?yán)飳?duì)應(yīng)寶貝。

這樣一個(gè)下單操作就包含了4部分,可以把這4部分看成是4張表,分別對(duì)這4張表進(jìn)行對(duì)應(yīng)的操作,就實(shí)現(xiàn)了業(yè)務(wù)。

但今天我要講的不是業(yè)務(wù)操作日志,因?yàn)椴煌?xiàng)目的業(yè)務(wù)不盡相同,所以它無法做成通用模塊,而我要講的,就是普通操作日志。

上面解釋了一大段,下面干貨就要亮相了,先洗把臉清醒下。

首先,哪些地方需要記錄操作日志?執(zhí)行insert、update、delete這3個(gè)操作的時(shí)候,就需要進(jìn)行日志,而日志執(zhí)行的先后順序如下

mysql管理系統(tǒng)操作日志設(shè)計(jì)舉例分析

順序清楚后,就來看下我寫的一份日志操作類吧,***版隨便謝謝的,重復(fù)代碼有點(diǎn)多,還未來得及優(yōu)化。

class LOG{      protected $primaryid;      protected $tbid;      protected $tbname;      protected $keys;      protected $values;      /**       * 參數(shù)說明       * int              $tbid       查詢指定表的id       * string           $tbname     數(shù)據(jù)庫表名       */     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()'         ));          //查詢修改前數(shù)據(jù)信息          $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'];          }          //查詢修改后數(shù)據(jù)信息          $rs = $db->select(0, 1, $this->tbname, '*', 'and tbid = '.$this->tbid);          $currentvalues = array_values($rs);          //前后信息進(jìn)行比較          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');

可以看到,一共只需要兩個(gè)參數(shù)即可,分別是表ID(主鍵)和表名稱。

另外需要強(qiáng)調(diào)一點(diǎn),表注釋和字段注釋一定要完整,因?yàn)橛涗浀男畔⑨?,目的就是為了查閱的時(shí)候能清楚哪個(gè)字段是干什么用的。

下面就看下成品吧

mysql管理系統(tǒng)操作日志設(shè)計(jì)舉例分析

mysql管理系統(tǒng)操作日志設(shè)計(jì)舉例分析

“mysql管理系統(tǒng)操作日志設(shè)計(jì)舉例分析”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI