程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 教您如何實現MySQL動態視圖

教您如何實現MySQL動態視圖

編輯:MySQL綜合教程

MySQL動態視圖的實現方法應該是我們都需要掌握的,下面就教您如何實現MySQL動態視圖的方法,希望對您能夠有所幫助。

用戶為C/S結構,每個用戶根據角色不同,能看到不同的數據。系統會根據某個標識生成一個數據內容,然後通過統一的視圖來訪問。

需求:

用戶為C/S結構,每個用戶根據角色不同,能看到不同的數據。系統會根據某個標識生成一個數據內容,然後通過統一的MySQL動態視圖來訪問。

要求,不能修改MySQL動態視圖,也不能在試圖外面再嵌套一層查詢。

設計:

系統通過某種方法生成一個唯一的ID(可以是應用端,也可以是數據庫的uuid),然後將試圖與這個id進行關聯即可。

代碼:
 

  1. drop table if exists test;   
  2. create table test (   
  3. id int not null,   
  4. name varchar(20) not null   
  5. );   
  6. insert into test values(1,'test1');   
  7. insert into test values(1,'test11');   
  8. insert into test values(1,'test111');   
  9. insert into test values(2,'test2');   
  10. insert into test values(2,'test22');   
  11. drop function if exists getSpid;   
  12. delimiter |   
  13. CREATE function getSpid()   
  14. RETURNS int   
  15. RETURN @spid;   
  16. |   
  17. delimiter ;   
  18. drop view if exists v_test;   
  19. create view v_test as   
  20. select * from test where id=getSpid();   
  21. -- 測試代碼   
  22. -- 開啟session 1   
  23. set @spid=1;   
  24. select * from v_test;   
  25. -- 開啟session 2   
  26. set @spid=2;   
  27. select * from v_test; 

說明:

將生成的ID保持到session變量裡面

然後建立自定義函數,返回這個變量

最後在MySQL動態視圖裡面調用這個函數

使用MySQL命令行備份及恢復數據庫

MySQL刪除重復記錄的方法

MySQL查詢緩存機制簡介

使用MySQL臨時表加速查詢

教您如何合理使用MySQL索引

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved