教您如何实现MySQL动态视图

数据库 MySQL
视图是MySQL中的重要概念,下文将为您解析介绍MySQL动态视图的实现方法,如果您在这方面遇到过类似的问题,不妨一看。

MySQL动态视图的实现方法应该是我们都需要掌握的,下面就教您如何实现MySQL动态视图的方法,希望对您能够有所帮助。

用户为C/S结构,每个用户根据角色不同,能看到不同的数据。系统会根据某个标识生成一个数据内容,然后通过统一的视图来访问。

需求:

用户为C/S结构,每个用户根据角色不同,能看到不同的数据。系统会根据某个标识生成一个数据内容,然后通过统一的MySQL动态视图来访问。

要求,不能修改MySQL动态视图,也不能在试图外面再嵌套一层查询。

设计:

系统通过某种方法生成一个唯一的ID(可以是应用端,也可以是数据库的uuid),然后将试图与这个id进行关联即可。

代码:
 

  1. drop table if exists test;   
  2. create table test (   
  3. id int not null,   
  4. name varchar(20) not null   
  5. );   
  6. insert into test values(1,'test1');   
  7. insert into test values(1,'test11');   
  8. insert into test values(1,'test111');   
  9. insert into test values(2,'test2');   
  10. insert into test values(2,'test22');   
  11. drop function if exists getSpid;   
  12. delimiter |   
  13. CREATE function getSpid()   
  14. RETURNS int   
  15. RETURN @spid;   
  16. |   
  17. delimiter ;   
  18. drop view if exists v_test;   
  19. create view v_test as   
  20. select * from test where id=getSpid();   
  21. -- 测试代码   
  22. -- 开启session 1   
  23. set @spid=1;   
  24. select * from v_test;   
  25. -- 开启session 2   
  26. set @spid=2;   
  27. select * from v_test; 

说明:

将生成的ID保持到session变量里面

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

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

 

 

【编辑推荐】

使用MySQL命令行备份及恢复数据库

MySQL删除重复记录的方法

MySQL查询缓存机制简介

使用MySQL临时表加速查询

教您如何合理使用MySQL索引

责任编辑:段燃 来源: 互联网
相关推荐

2010-11-25 14:56:46

MySQL全文查询

2010-11-22 16:05:53

MySQL多表插入

2010-10-08 10:37:00

MYSQL添加新字段

2010-10-26 10:48:16

ORACLE备份

2010-10-12 14:53:31

mysql索引优化

2010-11-25 14:49:08

MySQL查询最大值

2010-09-26 13:56:43

SQL远程查询

2010-11-18 16:27:37

2010-11-29 13:28:55

sybase自动备份

2010-11-25 10:44:30

2010-10-12 11:07:34

MySQL存储过程

2010-10-12 16:35:05

MySQL用户权限

2010-10-08 11:27:34

MySql访问限制

2010-11-16 09:49:22

Oracle重建索引

2010-10-13 15:59:21

MySQL索引

2010-10-14 10:18:28

MySQL数据库备份

2010-11-24 10:35:34

MySQL单表多字段

2010-10-12 10:10:55

mysql触发器

2010-10-11 09:41:23

MySQL环境变量

2010-10-19 16:58:34

SQL Server日
点赞
收藏

51CTO技术栈公众号