MySQL里动态视图的实现_MySQL
Jun 01, 2016 pm 01:56 PM需求:
用户为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变量里面
然后建立自定义函数,返回这个变量
最后在视图里面调用这个函数

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Comment utiliser le compte Xiaohongshu pour trouver des utilisateurs ? Puis-je retrouver mon numéro de téléphone portable ?

Connectez-vous à Ubuntu en tant que superutilisateur

Convertir le disque fixe VirtualBox en disque dynamique et vice versa

Explorez le guide Windows 11 : Comment accéder aux dossiers utilisateur sur votre ancien disque dur

Qu'est-ce que sudo et pourquoi est-ce important ?

Windows 11 KB5031455 ne parvient pas à s'installer, provoquant d'autres problèmes pour certains utilisateurs

Tutoriel : Comment supprimer un compte utilisateur normal dans le système Ubuntu ?

Analyse du mécanisme de stockage des mots de passe utilisateur dans le système Linux
