A. php中有沒有什麼方法可以實現實時監聽資料庫中的某張表的變化
最好的辦法是,在應用程序生命周期內,對於資料庫設置有事中核件鉤子,用於監聽程序對於資料庫的操作。這樣非常方便處理邏輯流程。
1 - 表的數據變化
表數據發生了變化,毫冊培譽無疑問是寫操作,包括以下幾種情形:
新建條目 create
更新條目 update
刪除條目 delete
以上三種都是寫操作,會對表數據寫入。
Laravel Observer
結語
上面的方法要求讀者有laravel框架的使用基礎,對於構建中大型應用非常有利。
B. 可以監控到資料庫變化的機制有哪些
存儲過程、資料庫日誌。當被監聽的資料庫中的數據發生變化時,可以監控到資料庫變化的機制基埋物有存儲過程、搏液資料庫日誌,從而獲得新增數據,或者修改的液氏數據。
C. c#程序實現,監控sql server2005資料庫中某一個表的變化,並獲取.求大神幫忙
嘗試這樣的思路:
假如你監控A表,將A表的所有ID寫入一個檢測表中
--創建表
createtableA_CheckUpdate(AIDint,BinaryCheckSumint,Remarkvarchar(50))
--將表A的初始數據插入檢測更新表中
insertintoA_CheckUpdateselectAID,Binary_CheckSum(*),''fromA
--你寫一個通信每隔一段時間比如5秒鍾檢查一次
--查詢A表被更新過的記錄
select*鬧州蠢from液陪A_CheckUpdate
whereexists(
selectAIDfromAwhereA.AID=A_CheckUpdate.AID
andbinary_checksum(*)<>A_CheckUpdate.BinaryCheckSum)
--如果跡氏是查看insert或者delete的數據請查看A_CheckUpdate是否有多餘的ID或者缺少的ID
selectA.IdfromAleftjoinA_CheckUpdateona.ID=A_CheckUpdate.ID
whereA_CheckUpdate.IDisnull
selectA_CheckUpdate.IdfromArightjoinA_CheckUpdateona.ID=A_CheckUpdate.ID
whereA.IDisnull
D. 怎樣監聽到資料庫的數據變化
在android中經常會用到改變資料庫內容後再去使用資料庫更新的內容,很多人會重新去query一遍,但是這樣的問題就是程序會特別占內存,而且有可能會摟關cursor而導致程序內存未釋放等等。其實android內部提供了一種ContentObserver的東西來監聽資料庫內容的變化。
ContentObserver的構造函數需要一個參數Hanlder,因為ContentObserver內部使用了一個實現Runnable介面的內部類NotificationRunnable,來實現資料庫內容的變化。需要使用hanlder去post消息。注冊ContentObserver的方法是:getContentResolver().registerContentObserver(uri, notifyForDescendents, observer).
上面3個參數為:uri----Uri類型,是需要監聽的資料庫的uri.
notifyForDescendents---boolean true的話就會監聽所有與此uri相關的uri。false的話則是直接特殊的uri才會監聽。一般都設置為true.
observer-----ContentObserver 就是需要的contentobserver.
初始化一個ContentObserver對象,重載onChange(boolean ),在這個方法里去操作資料庫的使用,針對變化後的使用。
E. 關於sql2008,怎麼監控某資料庫表變化情況
在每個表中添加觸發器~~
一旦數據有變化, 觸發器就被觸發~ 觸發器中寫代碼將這個變化寫入到你指定的日誌表中即可。
注意:是多個表的觸發器, 去操作同一個日誌表。
F. 如何實時監測資料庫變化
方法不唯一,而且越高的版本提供的工具虛跡越多,比如監控SQL命令,用Profile
監控數據差螞並一是可以直接在表上加觸發器,記錄變更日誌
資料庫還有審計audit功能,2016還有歷史表物漏,CDC等
G. C#winform程序怎麼監視資料庫的變化
首先,在要插入的數據表增祥團漏加觸發器,如果有數據插入,則將此信息插謹爛入一個中間表,表示或做有更新;其次,在C#端定義一個計時器timer,循環檢測中間表有無更新,有則提示,完成後清空中間表
H. 怎樣用JAVA來監聽資料庫里的變化
可以使用ContentObserver對象監聽,如下:
public final void registerContentObserver(Uri uri, boolean notifyForDescendents, ContentObserver observer)
功能:為指定的Uri注冊一個ContentObserver派生類實例,當給定的Uri發生改變時,回調該實例對象去處理。
參數:uri 需要觀察的Uri(需要在UriMatcher里注冊,否則該Uri也沒有意義了)
notifyForDescendents 為false 表示精確匹配,即只匹配該Uri
為true 表示可以同時匹配其派生的Uri,舉例如下:
假設UriMatcher 里注冊的Uri共有一下類型:
1 、content://com.qin.cb/student (學生)
2 、content://com.qin.cb/student/#
3、 content://com.qin.cb/student/schoolchild(小學生,派生的Uri)
假設我們當前需要觀察的Uri為content://com.qin.cb/student,如果發生數據變化的 Uri 為
content://com.qin.cb/student/schoolchild ,當notifyForDescendents為 false,那麼該ContentObserver會監聽不到,
但是當notifyForDescendents 為ture,能捕捉該Uri的資料庫變化。
I. 如何實時監測資料庫變化
然後在新增信息模塊將消息存入一個隊列,每隔固定時間(如500ms)向nodejs服務發送一次請求,比如http的post或UDP協議,並清空隊列。
每隔固定時間發送是為了減少發送次數,根據服務的實時性可以取消或者增加。
hu.js上朋友網用nodejs做的就是這樣的事情。
另一個,不理解「不在線的用戶會收到一個提示」,怎麼提示?提示可以拆成另一個服務,在推信息的時候可以根據用戶狀態判斷是調用哪個服務
J. 如何監控mysql資料庫的變化
1、打開資料庫配置文件my.ini (一般在資料庫安裝目錄)(D:\MYSQL)
2、在資料庫的最後一行添加
log=log.txt
代碼
3、重啟mysql資料庫
4、去資料庫數據目錄 我的是(D:\MYSQL\data) 你會發現多了一個log.txt文件
我的是在C:\Documents and Settings\All Users\Application Data\MySQL\MySQL Server 5.5\data
測試:
1、對資料庫操作
2、查看log.txt文件內容 如果發現有變化說明你就可以監控到mysql資料庫的變化
資料庫的查詢 刪除 更新 插入都可以查到
希望本篇文章可以幫助大家更快的二次開發 ^_^
日誌文件類型概述:
1.
錯誤日誌 記錄啟動、運行或停止mysqld時出現的問題。
My.ini配置信息:
#Enter a name for the error log file. Otherwise a default name will be used.
#log-error=d:/mysql_log_err.txt