如何实现MySQL里动态视图

WBOY
풀어 주다: 2016-06-07 14:51:29
원래의
1370명이 탐색했습니다.

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

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

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿