Mysql视图
Posted Mr_Echo
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysql视图相关的知识,希望对你有一定的参考价值。
1.什么是视图
通俗的讲,视图就是一条select语句执行后返回的结果集,所以我们在创建视图的时候,主要的工作就落在创建这条sql查询语句上。
2.视图的特性
视图是对若干张基本表的引用,一张虚表,查询语句执行的结果,不存储具体的数据(基本表数据发生了改变,视图也会跟着改变);
可以跟基本表一样,进行增删改查操作(ps:增删改操作有条件限制);
3.视图的作用
方便操作,特别是查询操作,减少复杂的sql语句,增强可读性;
更加安全,数据库授权命令不能限定到特定行和特定列,但是通过合理创建视图,可以把权限限定到行列级别;
4.使用场合
权限控制的时候,不希望用户访问表中某些含敏感信息的列。比如salary...
关键信息来源于多个复杂关联表,可以创建视图提取我们需要的信息,简化操作:
5.视图实例1---创建视图及查询数据操作
现有三张表:用户(user)、课程(course)、用户课程中间表(user_course),表结构及数据如下:
表定义:
-- ---------------------------- -- Table structure for `course` -- ---------------------------- DROP TABLE IF EXISTS `course`; CREATE TABLE `course` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `name` varchar(200) NOT NULL, `description` varchar(500) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of course -- ---------------------------- INSERT INTO `course` VALUES (‘1‘, ‘JAVA‘, ‘JAVA课程‘); INSERT INTO `course` VALUES (‘2‘, ‘C++‘, ‘C++课程‘); INSERT INTO `course` VALUES (‘3‘, ‘C语言‘, ‘C语言课程‘); -- ---------------------------- -- Table structure for `user` -- ---------------------------- DROP TABLE IF EXISTS `user`; CREATE TABLE `user` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `account` varchar(255) NOT NULL, `name` varchar(255) NOT NULL, `address` varchar(255) DEFAULT NULL, `others` varchar(200) DEFAULT NULL, `others2` varchar(200) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of user -- ---------------------------- INSERT INTO `user` VALUES (‘1‘, ‘user1‘, ‘小陈‘, ‘美国‘, ‘1‘, ‘1‘); INSERT INTO `user` VALUES (‘2‘, ‘user2‘, ‘小张‘, ‘日本‘, ‘2‘, ‘2‘); INSERT INTO `user` VALUES (‘3‘, ‘user3‘, ‘小王‘, ‘中国‘, ‘3‘, ‘3‘); -- ---------------------------- -- Table structure for `user_course` -- ---------------------------- DROP TABLE IF EXISTS `user_course`; CREATE TABLE `user_course` ( `id` bigint(20) NOT NULL AUTO_INCREMENT, `userid` bigint(20) NOT NULL, `courseid` bigint(20) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8; -- ---------------------------- -- Records of user_course -- ---------------------------- INSERT INTO `user_course` VALUES (‘1‘, ‘1‘, ‘2‘); INSERT INTO `user_course` VALUES (‘2‘, ‘1‘, ‘3‘); INSERT INTO `user_course` VALUES (‘3‘, ‘2‘, ‘1‘); INSERT INTO `user_course` VALUES (‘4‘, ‘2‘, ‘2‘); INSERT INTO `user_course` VALUES (‘5‘, ‘2‘, ‘3‘); INSERT INTO `user_course` VALUES (‘6‘, ‘3‘, ‘2‘);
以上是关于Mysql视图的主要内容,如果未能解决你的问题,请参考以下文章