Welcome

首页 / 数据库 / MySQL / MySQL里动态视图的实现

MySQL里动态视图的实现2010-08-23 csdn博客 老紫竹需求:

用户为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变量里面

然后建立自定义函数,返回这个变量

最后在视图里面调用这个函数