最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

MySQL里动态视图的实现_MySQL

来源:动视网 责编:小采 时间:2020-11-09 17:42:21
文档

MySQL里动态视图的实现_MySQL

MySQL里动态视图的实现_MySQL:需求: 用户为C/S结构,每个用户根据角色不同,能看到不同的数据。系统会根据某个标识生成一个数据内容,然后通过统一的视图来访问。 要求,不能修改视图,也不能在试图外面再嵌套一层查询。 设计: 系统通过某种方法生成一个唯一的ID(可以是应用端,也
推荐度:
导读MySQL里动态视图的实现_MySQL:需求: 用户为C/S结构,每个用户根据角色不同,能看到不同的数据。系统会根据某个标识生成一个数据内容,然后通过统一的视图来访问。 要求,不能修改视图,也不能在试图外面再嵌套一层查询。 设计: 系统通过某种方法生成一个唯一的ID(可以是应用端,也


  需求:

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

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

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

文档

MySQL里动态视图的实现_MySQL

MySQL里动态视图的实现_MySQL:需求: 用户为C/S结构,每个用户根据角色不同,能看到不同的数据。系统会根据某个标识生成一个数据内容,然后通过统一的视图来访问。 要求,不能修改视图,也不能在试图外面再嵌套一层查询。 设计: 系统通过某种方法生成一个唯一的ID(可以是应用端,也
推荐度:
标签: 用户 动态 实现
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top