php 视图详解,视图 · PHP知识总结 · 看云

视图是一个从一张或多张表中导出的虚拟表,视图数据来自定义视图的查询中使用的表,使用视图动态生成。通过视图,可以展现基表的部分数据。

在定义视图时,只是把视图的定义存放在数据库,并不保存视图的数据,直到用户使用视图时才进行数据的查询并返回操作,当需要从不同的服务器中获得数据时,使用视图可以很好的将结构相同的数据组织并返回。


**优点**

* 简化复杂sql操作,隐藏表间的复杂关系

* 可作为安全机制,用户可以通过设置视图,使特定的用户能查看或修改用户权限内的数据,其他数据表不能进行操作。

* 数据独立,视图结构一旦确定,可以屏蔽表结构变化对用户的影响。

**应用场景一:**

如果需要频繁获取user表的name字段和user_info表的name字段。则需要使用多表查询的sql语句进行查询。此时如果创建视图(view_user):

```

create view view_user as select user.name as username,user_info.name as info_name from user,user_info where user.id = user_info.userId;

```

使用以下语句则可以获取到user表的name和user_info的name字段

`select * from view_user;`


**应用场景二:**

假设需求发生变动,需要将user表进行拆分。拆分成user_a表和user_b表。此时会对user表的已有的代码逻辑造成影响,会提示user表不存在,因此需要重新修改代码的业务逻辑。

此时创建视图(view_user):(假设name字段唯一)

```

create view view_user as select a.name,a.age,b.sex from user_a as a, user_b as b where a.name=b.name;

```

那么,在PHP的业务逻辑中使用以下语句,不会发生报错。这就是实现了对数据库重构,却不影响程序运行。

`select * from view_user `

> 视图相关的MySQL指令

操作指令代码

创建视图CREATE VIEW 视图名(列1,列2...) AS SELECT (列1,列2...) FROM ...;使用视图sql语句修改视图CREATE OR REPLACE VIEW 视图名 AS SELECT [...] FROM [...];查看已有视图>SHOW TABLES [like...];(可以使用模糊查找)查看视图详情DESC 视图名或者SHOW FIELDS FROM 视图名删除视图DROP VIEW 视图名
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值