MySQL(基础篇)之视图

Jun 07, 2016 pm 03:03 PM
mysql アドバンテージ 効果 ベース 導入 ビュー

一: 视图的简介,作用,优点 1. 什么是视图? a. 视图是一种虚拟的表 ,是从数据库中一个或者多个表中导出的表 b. 数据库只存放了视图的定义,而并没有存放视图中的数据, 这些数据存放在原来的表中 c. 使用视图查询数据时,数据库系统会从原来的表中取出对应的记录



一: 视图的简介,作用,优点

1.       什么是视图?

a.       视图是一种虚拟的表,是从数据库中一个或者多个表中导出的表

b.       数据库只存放了视图的定义,而并没有存放视图中的数据,这些数据存放在原来的表中

c. 使用视图查询数据时,数据库系统会从原来的表中取出对应的记录

 

2.         视图的作用:

a.         使操作简便化

b.         增加数据的安全性

c.         提高表的逻辑独立性


3.         视图的优点:

a. 视点集中

b. 简化操作

c. 定制数据

d. 合并分割数据

· e. 安全性

 

二: 创建视图

CREATE [ ALGORITHM ={ UNDEFIEND | MERGE | TEMPTABLE }]

VIEW 视图名[ ( 属性清单) ]

AS SELECT 语句

[ WITH [ CASCADED | LOCAL ] CHECK OPTION ];

 

ALGORITHM 是可选参数,表示视图选择的算法;

“视图名”参数表示要创建的视图的名称;

“属性清单”是可选参数,其指定了视图中各种属性的名词,默认情况下与SELECT 语句中查询的属性相同;

SELECT 语句参数是一个完整的查询语句,标识从某个表查出某些满足条件的记录,将这些记录导入视图中;

WITH CHECK OPTION 是可选参数,表似乎更新视图时要保证在该视图的权限范围之内;

ALGORITHM 包括3 个选项UNDEFINED、MERGE 和TEMPTABLE。

UNDEFINED 选项表示MySQL 将自动选择所要使用的算法;

MERGE 选项表示将使用视图的语句与视图定义合并起来,使得视图定义的某一部分取代语句的对应部分;

TEMPTABLE 选项表示将视图的结果存入临时表,然后使用临时表执行语句;CASCADED是可选参数,表示更新视图时要满足所有相关视图和表的条件,该参数为默认值;

LOCAL 表示更新视图时,要满足该视图本身的定义条件即可;

 

例: 创建一个名为v1的视图,其中包含了t_book表的全部记录

Mysql>CREATE VIEW v1

AS

SELECT * FROM t_book;

接下来我们就可以对这个视图进行操作,查询视图中id为2的记录

Mysql>SELECT * FROM v1 WHERE id=2;

例: 创建一个名为v2的视图,其中只显示书名和价格信息

Mysql>CREATE VIEW v2

AS

SELECT bookName,price FROM t_book;

Mysql>SELECT * FROM v2;

现在v2视图中就只包含书名和价格的信息

 

例: 这样写的话,你会发现字段名变成了书名和价格

Mysql>CREATE VIEW v3(书名,价格)

AS

SELECT bookName,price FROM t_book;

Mysql>SELECT * FROM v2;

 

当然,也可以这么写:

Mysql>CREATE VIEW v4

AS

SELECT bookName AS '书名',price AS '价格' FROM t_book;

 

例: 根据t_book和t_booktype表建立视图,查询书名和书的类别

Mysql>CREATE VIEW v5

AS

SELECT bookName,bookTypeName FROM t_book t1,t_booktype t2 WHERE t1.bookTypeId=t2.id;

 

三:查看视图

4.1 DESCRIBE 语句查看视图基本信息

例: 查看v4视图的基本信息

Mysql>DESC v4;

 

4.2 SHOW TABLE STATUS LIKE 语句查看视图基本信息

例: 查看v5视图的基本信息

Mysql>SHOW TABLE STATUS LIKE 'v5';

可以很明显的看出 视图是虚表

4.3 SHOW CREATE VIEW 语句查看视图详细信息

例: 查看v5视图的详细信息

Mysql>SHOW CREATE VIEW v5;

 

4.3 在views 表中查看视图详细信息

Mysql>USE information_schema;

Mysql>SELECT * FROM views;

这样 我们就能看到所有已经创建的视图的信息

 

四: 修改视图

4.1 CREATE OR REPLACE VIEW 语句修改视图

CREATE OR REPLACE [ ALGORITHM ={ UNDEFINED | MERGE | TEMPTABLE }]

VIEW 视图名[( 属性清单)]

AS SELECT 语句

[ WITH [ CASCADED | LOCAL ] CHECK OPTION ];

如果视图存在就REPLACE该视图,如果不存在 就Create 该视图

 

例: Mysql>CREATE OR REPLACE VIEW v3

AS

SELECT * FROM t_book WHERE id =3;

 

4.2 ALTER 语句修改视图

ALTER [ ALGORITHM ={ UNDEFINED | MERGE | TEMPTABLE }]

VIEW 视图名[( 属性清单)]

AS SELECT 语句

[ WITH [ CASCADED | LOCAL ] CHECK OPTION ];

只能修改视图,不能创建视图

例: Mysql>ALTER VIEW v3

AS

SELECT * FROM t_book;

 

五: 更新视图

更新视图是指通过视图来插入(INSERT)、更新(UPDATE)和删除(DELETE)表中的数据。因为视图是一个虚拟的表,其中没有数据。通过视图更新时,都是转换基本表来更新。更新视图时,只能更新权限范围内的数据。超出了范围,就不能更新。

 

5.1 插入(INSERT)

例: Mysql>INSERT INTO v4 VALUES(NULL,'心理学',45,'三张',4);

 

5.2 更新(UPDATE)

例: Mysql>UPDATE v4 SET bookName='心理学2' WHERE id =5;

5.3 删除(DELETE)

Mysql>DELETE FROM v4 WHERE id =5;

通过视图来插入(INSERT)、更新(UPDATE)和删除(DELETE)时,都是对原表来进行操作.

 

六: 删除视图

删除视图是指删除数据库中已存在的视图。删除视图时,只能删除视图的定义,不会删除数据;

DROP VIEW [ IF EXISTS ] 视图名列表[ RESTRICT | CASCADE ]

例: 如果存在名为v4的视图,那么就删除.

Mysql>DROP VIEW IF EXISTS v4;

 

七: 总结

视图到这就结束了,大家好好消化下视图,下节将为大家带来触发器的使用,谢谢大家!MySQL(基础篇)之视图

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

PHPのビッグデータ構造処理スキル PHPのビッグデータ構造処理スキル May 08, 2024 am 10:24 AM

ビッグ データ構造の処理スキル: チャンキング: データ セットを分割してチャンクに処理し、メモリ消費を削減します。ジェネレーター: データ セット全体をロードせずにデータ項目を 1 つずつ生成します。無制限のデータ セットに適しています。ストリーミング: ファイルやクエリ結果を 1 行ずつ読み取ります。大きなファイルやリモート データに適しています。外部ストレージ: 非常に大規模なデータ セットの場合は、データをデータベースまたは NoSQL に保存します。

PHP で MySQL クエリのパフォーマンスを最適化するにはどうすればよいですか? PHP で MySQL クエリのパフォーマンスを最適化するにはどうすればよいですか? Jun 03, 2024 pm 08:11 PM

MySQL クエリのパフォーマンスは、検索時間を線形の複雑さから対数の複雑さまで短縮するインデックスを構築することで最適化できます。 PreparedStatement を使用して SQL インジェクションを防止し、クエリのパフォーマンスを向上させます。クエリ結果を制限し、サーバーによって処理されるデータ量を削減します。適切な結合タイプの使用、インデックスの作成、サブクエリの使用の検討など、結合クエリを最適化します。クエリを分析してボトルネックを特定し、キャッシュを使用してデータベースの負荷を軽減し、オーバーヘッドを最小限に抑えます。

PHP で MySQL のバックアップと復元を使用するにはどうすればよいですか? PHP で MySQL のバックアップと復元を使用するにはどうすればよいですか? Jun 03, 2024 pm 12:19 PM

PHP で MySQL データベースをバックアップおよび復元するには、次の手順を実行します。 データベースをバックアップします。 mysqldump コマンドを使用して、データベースを SQL ファイルにダンプします。データベースの復元: mysql コマンドを使用して、SQL ファイルからデータベースを復元します。

PHP を使用して MySQL テーブルにデータを挿入するにはどうすればよいですか? PHP を使用して MySQL テーブルにデータを挿入するにはどうすればよいですか? Jun 02, 2024 pm 02:26 PM

MySQLテーブルにデータを挿入するにはどうすればよいですか?データベースに接続する: mysqli を使用してデータベースへの接続を確立します。 SQL クエリを準備します。挿入する列と値を指定する INSERT ステートメントを作成します。クエリの実行: query() メソッドを使用して挿入クエリを実行します。成功すると、確認メッセージが出力されます。

MySQL 8.4 で mysql_native_password がロードされていないエラーを修正する方法 MySQL 8.4 で mysql_native_password がロードされていないエラーを修正する方法 Dec 09, 2024 am 11:42 AM

MySQL 8.4 (2024 年時点の最新の LTS リリース) で導入された主な変更の 1 つは、「MySQL Native Password」プラグインがデフォルトで有効ではなくなったことです。さらに、MySQL 9.0 ではこのプラグインが完全に削除されています。 この変更は PHP および他のアプリに影響します

PHP で MySQL ストアド プロシージャを使用するにはどうすればよいですか? PHP で MySQL ストアド プロシージャを使用するにはどうすればよいですか? Jun 02, 2024 pm 02:13 PM

PHP で MySQL ストアド プロシージャを使用するには: PDO または MySQLi 拡張機能を使用して、MySQL データベースに接続します。ストアド プロシージャを呼び出すステートメントを準備します。ストアド プロシージャを実行します。結果セットを処理します (ストアド プロシージャが結果を返す場合)。データベース接続を閉じます。

PHP を使用して MySQL テーブルを作成するにはどうすればよいですか? PHP を使用して MySQL テーブルを作成するにはどうすればよいですか? Jun 04, 2024 pm 01:57 PM

PHP を使用して MySQL テーブルを作成するには、次の手順が必要です。 データベースに接続します。データベースが存在しない場合は作成します。データベースを選択します。テーブルを作成します。クエリを実行します。接続を閉じます。

Oracleデータベースとmysqlの違い Oracleデータベースとmysqlの違い May 10, 2024 am 01:54 AM

Oracle データベースと MySQL はどちらもリレーショナル モデルに基づいたデータベースですが、Oracle は互換性、スケーラビリティ、データ型、セキュリティの点で優れており、MySQL は速度と柔軟性に重点を置いており、小規模から中規模のデータ セットに適しています。 ① Oracle は幅広いデータ型を提供し、② 高度なセキュリティ機能を提供し、③ エンタープライズレベルのアプリケーションに適しています。① MySQL は NoSQL データ型をサポートし、② セキュリティ対策が少なく、③ 小規模から中規模のアプリケーションに適しています。

See all articles