MySQL视图原理与基本操作示例

吾爱主题 阅读:98 2024-04-05 14:00:27 评论:0

本文实例讲述了MySQL视图原理与基本操作。分享给大家供大家参考,具体如下:

概述

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

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

基本操作

建立视图

?
1 CREATE VIEW view_test(qty,price,total) AS SELECT quantity,price,quantity*price FROM t;

多表视图

?
1 CREATE VIEW stu_class(id, name ,glass) AS SELECT student.s_id,student. name ,stu_info.glass FROM student,stu_info WHERE student.s_id = stu_info.s_id;

查看视图

DESCRIBE 视图名

DESC 视图名

查看视图基本信息

?
1 SHOW TABLE STATUS LIKE '视图名' ;

查看视图的建表信息

?
1 SHOWCREATE VIEW 视图名

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

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

?
1 select * from information_schema.views;

修改视图

REPLACE语句

?
1 CREATE OR REPLACE VIEW view_test AS SELECT * FROM t;

ALTER语句

?
1 ALTER VIEW view_test SELECT name FROM t;

删除视图

?
1 DROP VIEW IF EXISTS stu_glass

建表语句示例

?
1 2 3 4 /*获取系统组织结构   *包括用户名称、用户ID、所属店面名称、所属店面ID、创建时间...   */ CREATE VIEW organizationTableView as select id,storename,regdate from v9_qd_account;
?
1 2 3 4 /*获取当天的Cpz安装数据(按用户分组汇总)   *包括用户ID、Cpz汇总值...   */ CREATE VIEW TodayCpzTableView as select storeid,storename, count (id) as total, sum (tui_num) as tui_num from v9_qd_dev where days = DATE_FORMAT(NOW(), '%Y%m%d' ) group by storeid;
?
1 2 3 4 /*获取当月每天的Cpz安装数据(按天、用户分组汇总)   *包括日期(天)、用户ID、Cpz汇总值、CpzApp汇总值、重复Cpz汇总值...   */ CREATE VIEW HistoryCurrentMonthDayView as select storeid,storename, count (id) as total, sum (tui_num) as tui_num,days from v9_qd_dev where days > DATE_FORMAT(NOW(), '%Y%m' ) group by storeid,days;
?
1 2 3 4 /*获取每月的Cpz安装数据(按月、用户分组汇总)   *包括日期(天)、用户ID、Cpz汇总值、CpzApp汇总值、重复Cpz汇总值...   */ CREATE VIEW HistoryMonthTableView as select storeid,storename, count (id) as total, sum (tui_num) as tui_num, DATE_FORMAT(FROM_UNIXTIME(installdate), '%Y%m' ) as months from v9_qd_dev group by storeid,months;
?
1 2 3 4 /*根据输入的IMEI获取Cpz安装数据()   *包括IMEI、账户ID、店面ID、安装时间、是否重复安装、安装app个数、手机型号   */ CREATE VIEW QueryCpzDatumByIMEI as select storeid,storename,verify,tui_num,sn,idfa,imei,devms,installdate from v9_qd_dev;
?
1 2 //今天 DATE_FORMAT(NOW(), '%Y%m%d' );

希望本文所述对大家MySQL数据库计有所帮助。

原文链接:http://www.cnblogs.com/mr-amazing/p/4613338.html

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容