教您如何實現(xiàn)MySQL動態(tài)視圖
MySQL動態(tài)視圖的實現(xiàn)方法應(yīng)該是我們都需要掌握的,下面就教您如何實現(xiàn)MySQL動態(tài)視圖的方法,希望對您能夠有所幫助。
用戶為C/S結(jié)構(gòu),每個用戶根據(jù)角色不同,能看到不同的數(shù)據(jù)。系統(tǒng)會根據(jù)某個標(biāo)識生成一個數(shù)據(jù)內(nèi)容,然后通過統(tǒng)一的視圖來訪問。
需求:
用戶為C/S結(jié)構(gòu),每個用戶根據(jù)角色不同,能看到不同的數(shù)據(jù)。系統(tǒng)會根據(jù)某個標(biāo)識生成一個數(shù)據(jù)內(nèi)容,然后通過統(tǒng)一的MySQL動態(tài)視圖來訪問。
要求,不能修改MySQL動態(tài)視圖,也不能在試圖外面再嵌套一層查詢。
設(shè)計:
系統(tǒng)通過某種方法生成一個唯一的ID(可以是應(yīng)用端,也可以是數(shù)據(jù)庫的uuid),然后將試圖與這個id進(jìn)行關(guān)聯(lián)即可。
代碼:
- 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變量里面
然后建立自定義函數(shù),返回這個變量
最后在MySQL動態(tài)視圖里面調(diào)用這個函數(shù)
【編輯推薦】