我们从一个结果集中查询信息一般都是select * from (select...),每次都要编写from (select...)非常麻烦,于是我们将结果集保存起来,这就是视图的便利。
创建视图的命令为:
create view 视图名称 as (select 语句)
更新视图的命令为:(如果包含聚合函数等是无法修改值的,也就是说计算过后的值),更新操作会同步通新原表数据
update goods set 字段=值
删除视图的命令为:
drop view if exists 视图名称
视图的作用:
(1).权限控制:例如我们只允许查询到商品表中的id,名称,价格,使用视图后查询视图表goods是无法查看到原表shop_goods的其他字段的
create view goods as select id,name,price from shop_goods
select * from goods;
(2).简化复杂的查询:例如select * from (select....)多层嵌套,使用视图更快更方便;视图保存在information_schema库中,并不会因为mysql重启等原因失效.
Left join:即左连接,是以左表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将左表所有的查询信息列出,而右表只列出ON后条件与左表满足的部分。左连接全称为左外连接,是外连接的一种。Right join:即右连接,是以右表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将右表...
1.floor(x)返回小于x的整数,向下取整,用法,商品的价格是浮点型的,需要向下取整 eg:select id,title,floor(price) from shopgoods2.rand()返回0-1之间的随机数 select rand() select rand()...
触发器是一种特殊的事务,可以监听到Mysql的(insert/update/delete)的操作并触发相应的(insert/update/delete)操作. 触发器的创建主要有4个要素:(1).监听地点(...
由于在开发中不小心删除客户上传的商品数据,客户本身也不好说话,只好恢复数据库,记录下过程。原理是数据库开启bin-log功能,然后再通过备份的bin-log进行数据库恢复。先查找备份的数据库日志二进制文件。一般在mysql的data文件夹中,文件名大概为mysql-bin.00001,具体看文件的修...
项目和第三方系统对接,由于第三方开发人员属于兼职,数据库结构不一致的问题只能我来处理。此处文章用本地模拟演示。数据库资料:1号服务器: 账号root 密码root IP:127.0.0.1 数据库名称:data1 2号服务器...