这篇文章主要介绍MySQL视图原理的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

具体如下:

概述

视图是一个虚拟表,其内容由查询定义。同真实的表一样,视图包含一系列带有名称的列和行数据。但是视图并不在数据库中以存储的数据值集形式存在。行和列数据来自由定义视图的查询所引用的表,并在引用视图时动态生成。

对其中所引用的基础表来说,视图的作用类似于筛选。

基本操作

建立视图

CREATEVIEWview_test(qty,price,total)ASSELECTquantity,price,quantity*priceFROMt;

多表视图

CREATEVIEWstu_class(id,name,glass)ASSELECTstudent.s_id,student.name,stu_info.glassFROMstudent,stu_infoWHEREstudent.s_id=stu_info.s_id;

查看视图

DESCRIBE 视图名

DESC 视图名

查看视图基本信息

SHOWTABLESTATUSLIKE'视图名';

查看视图的建表信息

SHOWCREATEVIEW视图名

在VIEW表中查看视图详细信息

在mysql的information_schema数据库下的views表中存储了所有的视图定义,可以用select查看

select*frominformation_schema.views;

修改视图

REPLACE语句

CREATEORREPLACEVIEWview_testASSELECT*FROMt;

ALTER语句

ALTERVIEWview_testSELECTnameFROMt;

删除视图

DROPVIEWIFEXISTSstu_glass

建表语句示例

/*获取系统组织结构*包括用户名称、用户ID、所属店面名称、所属店面ID、创建时间...*/CREATEVIEWorganizationTableViewasselectid,storename,regdatefromv9_qd_account;

/*获取当天的Cpz安装数据(按用户分组汇总)*包括用户ID、Cpz汇总值...*/CREATEVIEWTodayCpzTableViewasselectstoreid,storename,count(id)astotal,sum(tui_num)astui_numfromv9_qd_devwheredays=DATE_FORMAT(NOW(),'%Y%m%d')groupbystoreid;

/*获取当月每天的Cpz安装数据(按天、用户分组汇总)*包括日期(天)、用户ID、Cpz汇总值、CpzApp汇总值、重复Cpz汇总值...*/CREATEVIEWHistoryCurrentMonthDayViewasselectstoreid,storename,count(id)astotal,sum(tui_num)astui_num,daysfromv9_qd_devwheredays>DATE_FORMAT(NOW(),'%Y%m')groupbystoreid,days;

/*获取每月的Cpz安装数据(按月、用户分组汇总)*包括日期(天)、用户ID、Cpz汇总值、CpzApp汇总值、重复Cpz汇总值...*/CREATEVIEWHistoryMonthTableViewasselectstoreid,storename,count(id)astotal,sum(tui_num)astui_num,DATE_FORMAT(FROM_UNIXTIME(installdate),'%Y%m')asmonthsfromv9_qd_devgroupbystoreid,months;

/*根据输入的IMEI获取Cpz安装数据()*包括IMEI、账户ID、店面ID、安装时间、是否重复安装、安装app个数、手机型号*/CREATEVIEWQueryCpzDatumByIMEIasselectstoreid,storename,verify,tui_num,sn,idfa,imei,devms,installdatefromv9_qd_dev;

//今天DATE_FORMAT(NOW(),'%Y%m%d');

以上是“MySQL视图原理的示例分析”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!