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

MySQL裡動態視圖的實現

編輯:關於MYSQL數據庫

  需求:

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

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

  設計:

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

  代碼:

drop table if exists test;   
create table test (   
    id int not null,   

    name varchar(20) not null  
);   
insert into test values(1,'test1');   
insert into test values(1,'test11');   
insert into test values(1,'test111');   
insert into test values(2,'test2');   
insert into test values(2,'test22');   
drop function if exists getSpid;   
delimiter |   
CREATE function getSpid()   
    RETURNS int  
  RETURN @spid;   
|   
delimiter ;   
drop vIEw if exists v_test;   
create vIEw v_test as   
  select * from test where id=getSpid();   
     
-- 測試代碼   
-- 開啟session 1  
set @spid=1;   
select * from v_test;   
-- 開啟session 2  
set @spid=2;   
select * from v_test;  

  說明:

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

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

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

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