系統通過某種方法生成一個唯一的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變量裡面
然後建立自定義函數,返回這個變量
最後在視圖裡面調用這個函數