Inhaltsverzeichnis
view视图
一、视图定义
二、创建视图
三、视图与表的关系
Heim Datenbank MySQL-Tutorial 小贝_mysqlview视图学习_MySQL

小贝_mysqlview视图学习_MySQL

Jun 01, 2016 pm 12:59 PM
视图

view视图

简要:
1、视图定义
2、创建视图
3、视图与表的关系
4、视图种类

一、视图定义

视图起因: 查询每个栏目最贵的商品=>

selectgoods_id,goods_name,shop_price from goods order by cat_id asc,shop_price desc; 查询结果,当成一张表看

如果某个查询结果出现的非常频繁,也就是说,拿这个结果进行子查询出现的非常频繁.

createtable g2 like goods;insert into g2 select ….

上面两句,是想保存一个查询结果到表里面,供其它查询用。

视图定义: 视图是由查询结果形成的一张虚拟表。

 

二、创建视图

mysql>CREATE TABLE t (qty INT, price INT);

mysql>INSERT INTO t VALUES(3, 50);

mysql>CREATE VIEW v AS SELECT qty, price, qty*price AS value FROM t;

mysql>SELECT * FROM v;

 

为什么需要视图?

a、简化查询语句

b、可以控制列权限

把表的权限封闭,但是开放相对应的视图权限。视图里只开放部分列部分数据

c、大数据分表时可以用视图把所分的表形成一张视图

 

三、视图与表的关系

测试时用到的表结构及数据

create table t

(id int primary keyauto_increment,

type tinyint unsigned,

name char(5) not nulldefault '',

money tinyint unsigned

)engine=myisamcharset=utf8;

insert intot(type,name,money) values(1,'1a',4),

(1,'1b',3),(2,'2a',3),(1,'1c',4),(2,'2b',5),(3,'3a',5);

问题1: 视图是表的查询结果,因此表的数据改变了,会影响视图的结果

\

\

修改原始表t的id为6的数据

\

查看视图:

 

\

问题2: 视图改变了呢?

情况一:视图的数据与表的数据一一对应,如上述例子中的表t与视图t_view1

1、修改视图t_view1的id为6的数据

 

\

查看原始表t

\

2、往视图t_view1插入数据

\

查看原始表t

\

3、删除视图t_view1id为7的数据

\

查看原始表t

\

情况2: 视图只是原始表的统计结果,并不与原始表数据一一对应

(备注: 创建统计t表相同type的money字段总和的视图)

\

试着修改下视图t_view2的数据

\

假设可以进行修改,那么type为1的money总和加上3后,怎么对应原始表各个type为1的数据。显然,这是没办法的。因此报错

从上面这两种情况,得到:

1、视图增删改也会影响表,但是,视图并不总能增删改

2、视图的数据与表的数据一一对应时,则可以

3、对于视图insert还应注意,视图必须包含表中没有默认值的列

四、视图的种类

4.1、查看视图创建语法

\

 

针对algorithm的用法:

a、undefined: 由系统默认

b、merge:当algorithm为此值时,创建的视图只是单纯的sql语句存在而不是以虚拟结果表的形式存在。但使用此视图时,创建视图的sql语句会与后面的sql语句进行优化,最后得到一条新的sql语句

以merge视图的方式,求得表t中type相同的money最大值

 

\

再对视图t_view3进行分组

\

显然,这个结果不是我们想要的结果。运行 上述sql语句等同于

\

 

这是因为merge不是以虚拟结果表存在,而仅仅是sql语句,因此会与后面的sql语句进行优化后,再进行执行。

c、temptable:会把视图当做虚拟结果表

以temptable视图的方式,求得表t中type相同的money最大值

\

再进行对type进行分组

\

 

从上面这两种情况,得到:

创建视图建议指定视图的类型为临时表

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Der Standby-Modus von iOS 17 verwandelt ein ladendes iPhone in einen Home-Hub Der Standby-Modus von iOS 17 verwandelt ein ladendes iPhone in einen Home-Hub Jun 06, 2023 am 08:20 AM

Mit iOS 17 führt Apple den Standby-Modus ein, ein neues Anzeigeerlebnis zum Laden von iPhones in horizontaler Ausrichtung. In dieser Position kann das iPhone eine Reihe von Vollbild-Widgets anzeigen und wird so zu einem nützlichen Home-Hub. Der Standby-Modus wird automatisch aktiviert, wenn ein iPhone mit iOS 17 horizontal auf dem Ladegerät platziert wird. Sie können Uhrzeit, Wetter, Kalender, Musiksteuerung, Fotos und mehr anzeigen. Sie können durch die verfügbaren Standby-Optionen nach links oder rechts wischen und dann zum Anpassen lange drücken oder nach oben/unten wischen. Sie können beispielsweise zwischen analoger Ansicht, digitaler Ansicht, Blasenschrift und Tageslichtansicht wählen, wobei sich die Hintergrundfarbe im Laufe der Zeit je nach Zeit ändert. Es gibt einige Optionen

So implementieren Sie bearbeitbare Tabellen in Vue So implementieren Sie bearbeitbare Tabellen in Vue Nov 08, 2023 pm 12:51 PM

Tabellen sind ein wesentlicher Bestandteil vieler Webanwendungen. Tabellen enthalten normalerweise große Datenmengen, daher erfordern Tabellen einige spezifische Funktionen, um die Benutzererfahrung zu verbessern. Eine der wichtigen Funktionen ist die Bearbeitbarkeit. In diesem Artikel untersuchen wir, wie bearbeitbare Tabellen mit Vue.js implementiert werden, und stellen spezifische Codebeispiele bereit. Schritt 1: Daten vorbereiten Zuerst müssen wir die Daten für die Tabelle vorbereiten. Wir können ein JSON-Objekt verwenden, um die Daten der Tabelle zu speichern und sie in der Dateneigenschaft der Vue-Instanz zu speichern. In diesem Fall

Verstehen Sie die Unterschiede und Vergleiche zwischen SpringBoot und SpringMVC Verstehen Sie die Unterschiede und Vergleiche zwischen SpringBoot und SpringMVC Dec 29, 2023 am 09:20 AM

Vergleichen Sie SpringBoot und SpringMVC und verstehen Sie deren Unterschiede. Mit der kontinuierlichen Weiterentwicklung der Java-Entwicklung ist das Spring-Framework für viele Entwickler und Unternehmen zur ersten Wahl geworden. Im Spring-Ökosystem sind SpringBoot und SpringMVC zwei sehr wichtige Komponenten. Obwohl beide auf dem Spring-Framework basieren, gibt es einige Unterschiede in Funktionen und Verwendung. Dieser Artikel konzentriert sich auf den Vergleich von SpringBoot und Spring

Wie verwende ich das CodeIgniter4-Framework in PHP? Wie verwende ich das CodeIgniter4-Framework in PHP? May 31, 2023 pm 02:51 PM

PHP ist eine sehr beliebte Programmiersprache und CodeIgniter4 ist ein häufig verwendetes PHP-Framework. Bei der Entwicklung von Webanwendungen ist die Verwendung von Frameworks sehr hilfreich. Sie können den Entwicklungsprozess beschleunigen, die Codequalität verbessern und die Wartungskosten senken. In diesem Artikel wird die Verwendung des CodeIgniter4-Frameworks vorgestellt. Installation des CodeIgniter4-Frameworks Das CodeIgniter4-Framework kann von der offiziellen Website (https://codeigniter.com/) heruntergeladen werden. Runter

Laravel-Entwicklung: Wie generiert man Ansichten mit Laravel View? Laravel-Entwicklung: Wie generiert man Ansichten mit Laravel View? Jun 14, 2023 pm 03:28 PM

Laravel ist derzeit eines der beliebtesten PHP-Frameworks und seine leistungsstarken Funktionen zur Ansichtsgenerierung sind beeindruckend. Eine Ansicht ist eine Seite oder ein visuelles Element, das dem Benutzer in einer Webanwendung angezeigt wird und Code wie HTML, CSS und JavaScript enthält. Mit LaravelView können Entwickler eine strukturierte Vorlagensprache verwenden, um Webseiten zu erstellen und entsprechende Ansichten über Controller und Routing zu generieren. In diesem Artikel erfahren Sie, wie Sie mit LaravelView Ansichten generieren. 1. Was

Was sind die Ansichten von Word? Was sind die Ansichten von Word? Mar 19, 2024 pm 06:10 PM

Ich vermute, dass viele Schüler Wortsatzfähigkeiten erlernen möchten, aber der Herausgeber sagt Ihnen insgeheim, dass Sie die Wortansichten klar verstehen müssen. In Word2007 stehen den Benutzern 5 Ansichten zur Auswahl . Ansicht, Leselayout-Ansicht, Web-Layout-Ansicht, Gliederungsansicht und normale Ansicht, lernen wir heute diese 5 Wortansichten mit dem Editor kennen. 1. Seitenansicht Die Seitenansicht kann das Erscheinungsbild des Druckergebnisses des Word2007-Dokuments anzeigen, das hauptsächlich Kopfzeilen, Fußzeilen, Grafikobjekte, Spalteneinstellungen, Seitenränder und andere Elemente umfasst. Dies ist die Seitenansicht, die dem Druckergebnis am nächsten kommt. 2. Leselayoutansicht Die Leselayoutansicht zeigt Word2007-Dokumente und Office im Spaltenstil eines Buches an

Detaillierte Erläuterung der Ansichten im Django-Framework Detaillierte Erläuterung der Ansichten im Django-Framework Jun 17, 2023 am 10:18 AM

Django ist ein hochgradig anpassbares Web-Framework, das viele praktische Tools und Bibliotheken bereitstellt, mit denen Entwickler schnell leistungsstarke, skalierbare Webanwendungen erstellen können. Unter diesen sind Ansichten eine der wichtigsten Komponenten des Django-Frameworks. Ansichten sind dafür verantwortlich, Anfragen von Kunden zu verarbeiten und entsprechende Antworten zurückzugeben. In diesem Artikel tauchen wir tief in die Ansichten im Django-Framework ein und erklären, wie man damit leistungsstarke, anpassbare Webanwendungen erstellt. 1. Das Grundkonzept der Ansichten in Django

Microsoft aktualisiert Visual Studio Code 1.80 Microsoft aktualisiert Visual Studio Code 1.80 Jul 10, 2023 pm 08:13 PM

Microsoft hat kürzlich Visual Studio Code 1.80 veröffentlicht. Obwohl dieses Update im Juli veröffentlicht wurde, wird es von den Beamten immer noch als Juni-Update bezeichnet. Nachdem Benutzer dieses Update installiert haben, kann das integrierte Terminal Bilder direkt anzeigen und auch Zusatzfunktionen wurden optimiert. In der zuvor veröffentlichten Vorschauversion von Visual Studio Code wurde die Unterstützung für Bilder im Terminal unterstützt und ist in der neuen Version 1.80 standardmäßig aktiviert. Um das Bild im Terminal anzeigen zu können, werden die Bildpixeldaten durch eine spezielle Escape-Sequenz in Text umgewandelt und schließlich auf das Terminal geschrieben. Wenn Sie typische PNG-, GIF- oder JPEG-Dateien an das Terminal weiterleiten möchten, müssen Sie das imgcatpython-Paket installieren und dann imgc im Terminal ausführen

See all articles