MySQL动态视图的实现方法应该是我们都需要掌握的,下面就教您如何实现MySQL动态视图的方法,希望对您能够有所帮助。
我们提供的服务有:做网站、成都网站设计、微信公众号开发、网站优化、网站认证、岱岳ssl等。为1000多家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的岱岳网站制作公司
用户为C/S结构,每个用户根据角色不同,能看到不同的数据。系统会根据某个标识生成一个数据内容,然后通过统一的视图来访问。
需求:
用户为C/S结构,每个用户根据角色不同,能看到不同的数据。系统会根据某个标识生成一个数据内容,然后通过统一的MySQL动态视图来访问。
要求,不能修改MySQL动态视图,也不能在试图外面再嵌套一层查询。
设计:
系统通过某种方法生成一个唯一的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查询缓存机制简介
使用MySQL临时表加速查询
教您如何合理使用MySQL索引
新闻标题:教您如何实现MySQL动态视图
本文地址:http://www.mswzjz.cn/qtweb/news40/18390.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能