Heim Datenbank MySQL-Tutorial 理解SQL SERVER中的逻辑读,预读和物理读

理解SQL SERVER中的逻辑读,预读和物理读

Jun 07, 2016 pm 05:36 PM
培训课程 数据库查询

www.91xueit.com韩老师IT系统培训课程优化SQL性能,你必须理解数据库查询数据的细节,在查询分析器中打开IO统计,setstatisticsioon,就能查看查询过程关于逻辑

韩老师IT系统培训课程

 

       优化SQL性能,你必须理解数据库查询数据的细节,在查询分析器中打开IO统计,set statistics io on ,就能查看查询过程 关于逻辑读,预读和物理读的显示。下面给大家讲解数据库查询数据的细节,你也就明白了什么是关于逻辑读,预读和物理读 要想把这几个概念弄清楚必须了解数据库查询数据的细节。

SQL SERVER数据存储的形式

      在谈到几种不同的读取方式之前,首先要理解SQL SERVER数据存储的方式.SQL SERVER存储的最小单位为页(Page).每一页大小为8k,SQL SERVER对于页的读取是原子性,要么读完一页,要么完全不读,不会有中间状态。而页之间的数据组织结构为B树(请参考我之前的博文).所以SQL SERVER对于逻辑读,预读,和物理读的单位是页.

image

      SQL SERVER一页的总大小为:8K

      但是这一页存储的数据会是:8K=8192字节-96字节(页头)-36字节(行偏移)=8060字节

      所以每一页用于存储的实际大小为8060字节.

      比如上面AdventureWorks中的Person.Address表,通过SSMS看到这个表的数据空间为:

image

      我们可以通过公式大概推算出占用了多少页:2.250*1024*1024/8060(每页的数据容量)≈293 - 表中非数据占用的空间≈290(上图中的逻辑读取数)

SQL SERVER查询语句执行的顺序

      SQL SERVER查询执行的步骤如果从微观来看,那将会非常多。这里为了讲述逻辑读等概念,,我从比较高的抽象层次来看:

image

      图有些粗糙。

      下面我解释一下图。当遇到一个查询语句时,SQL SERVER会走第一步,分别为生成执行计划(占用CPU和内存资源),同步的用估计的数据去磁盘中取得需要取的数据(占用IO资源,这就是预读),注意,两个第一步是并行的,SQL SERVER通过这种方式来提高查询性能.

      然后查询计划生成好了以后去缓存读取数据.当发现缓存缺少所需要的数据后让缓存再次去读硬盘(物理读)

      最后从缓存中取出所有数据(逻辑读)。

      下面我再通过一个简单的例子说明一下:

image

      这个估计的页数数据可以通过这个DMV看到:

image

    当我们第一次查询完成后,再次进行查询时,所有请求的数据这时已经在缓存中,SQL SERVER这时只要对缓存进行读取就行了,也就是只用进行逻辑读:

image

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

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

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)

So lösen Sie das Problem des Überlaufs der Datenbankabfragenummer in der Java-Entwicklung So lösen Sie das Problem des Überlaufs der Datenbankabfragenummer in der Java-Entwicklung Jun 29, 2023 pm 06:46 PM

So lösen Sie das Problem des Datenbankabfragenummernüberlaufs in der Java-Entwicklung. Titel: So lösen Sie das Problem des Datenbankabfragenummernüberlaufs in der Java-Entwicklung. Zusammenfassung: Mit der Entwicklung des Internets und der allmählichen Zunahme der Datenmenge Auch Datenbankabfragen nehmen zu. Bei der Java-Entwicklung kann es aufgrund von Speicherbeschränkungen zu einem Überlauf bei der Anzahl der Datenbankabfragen kommen. In diesem Artikel werden verschiedene Möglichkeiten zur Lösung dieses Problems vorgestellt. Text: Datenbankabfrageanweisungen optimieren Zunächst können wir dieses Problem aus der Perspektive der Optimierung von Datenbankabfrageanweisungen lösen. wir können verwenden

So fragen Sie eine Datenbank ab und zeigen die Ergebnisse mit PHP an So fragen Sie eine Datenbank ab und zeigen die Ergebnisse mit PHP an May 02, 2024 pm 02:15 PM

Schritte zur Verwendung von PHP zum Abfragen der Datenbank und Anzeigen der Ergebnisse: Herstellen einer Verbindung zur Datenbank, Abfragen der Ergebnisse, Durchlaufen der Zeilen der Abfrageergebnisse und Ausgeben spezifischer Spaltendaten.

Laravel-Middleware: Fügen Sie Ihrer Anwendung Datenbankabfragen und Leistungsüberwachung hinzu Laravel-Middleware: Fügen Sie Ihrer Anwendung Datenbankabfragen und Leistungsüberwachung hinzu Jul 28, 2023 pm 02:53 PM

Laravel Middleware: Hinzufügen von Datenbankabfragen und Leistungsüberwachung zu Anwendungen Einführung: Datenabfragen und Leistungsüberwachung sind bei der Entwicklung von Webanwendungen sehr wichtig. Laravel bietet eine bequeme Möglichkeit, diese Anforderungen zu erfüllen, nämlich Middleware. Middleware ist eine Technologie, die zwischen Anfragen und Antworten verarbeitet. Sie kann eine gewisse Logik ausführen, bevor die Anfrage den Controller erreicht oder nachdem die Antwort an den Benutzer zurückgegeben wurde. In diesem Artikel wird erläutert, wie Sie die Laravel-Middleware zum Implementieren von Datenbankabfragen und zur Leistungsüberwachung verwenden. 1. Erstellen Sie die Mitte

Tipps für PHP-Datenbankabfragen: So verwenden Sie die Funktion mysqli_query zum Durchführen von SQL-Abfragen Tipps für PHP-Datenbankabfragen: So verwenden Sie die Funktion mysqli_query zum Durchführen von SQL-Abfragen Jul 29, 2023 pm 04:42 PM

Tipps für PHP-Datenbankabfragen: So verwenden Sie die Funktion mysqli_query zum Durchführen von SQL-Abfragen Bei der Entwicklung von PHP-Anwendungen ist die Interaktion mit der Datenbank ein sehr wichtiger Teil. Für Abfrageoperationen stellt PHP einige integrierte Funktionen zum Ausführen von SQL-Anweisungen bereit. Dieser Artikel konzentriert sich auf die Verwendung der Funktion mysqli_query, um Entwicklern dabei zu helfen, Datenbankabfragevorgänge besser durchzuführen. 1. Einführung in die Funktion mysqli_query Die Funktion mysqli_query ist eine integrierte Funktion von PHP.

Implementieren Sie einen Fehlerbehandlungsmechanismus für Datenbankabfragen in React Query Implementieren Sie einen Fehlerbehandlungsmechanismus für Datenbankabfragen in React Query Sep 28, 2023 pm 02:40 PM

Implementierung des Fehlerbehandlungsmechanismus von Datenbankabfragen in ReactQuery ReactQuery ist eine Bibliothek zum Verwalten und Zwischenspeichern von Daten und erfreut sich im Front-End-Bereich immer größerer Beliebtheit. In Anwendungen müssen wir häufig mit Datenbanken interagieren, und Datenbankabfragen können verschiedene Fehler verursachen. Daher ist die Implementierung eines effektiven Fehlerbehandlungsmechanismus von entscheidender Bedeutung, um die Anwendungsstabilität und das Benutzererlebnis sicherzustellen. Der erste Schritt besteht darin, ReactQuery zu installieren. Fügen Sie es mit dem folgenden Befehl zum Projekt hinzu: n

Laravel-Entwicklung: Wie verwende ich Eloquent ORM für Datenbankabfragen? Laravel-Entwicklung: Wie verwende ich Eloquent ORM für Datenbankabfragen? Jun 14, 2023 pm 12:47 PM

Laravel ist ein beliebtes PHP-Entwicklungsframework, das eine Reihe von Tools und Hilfsfunktionen bereitstellt, um die Entwicklung von Webanwendungen zu beschleunigen. Unter diesen ist EloquentORM eines der Tools, die für Datenbankoperationen im Laravel-Framework verwendet werden und es Laravel-Entwicklern ermöglichen, die Datenbank schneller abzufragen und zu betreiben. In diesem Artikel befassen wir uns mit der Verwendung von EloquentORM für Datenbankabfragen. EloquentORM installieren Zuerst müssen wir es installieren

Front-End-Leistungsstrategien zur Optimierung von Datenbankabfragen in React Query Front-End-Leistungsstrategien zur Optimierung von Datenbankabfragen in React Query Sep 26, 2023 am 11:38 AM

Front-End-Leistungsstrategien zur Optimierung von Datenbankabfragen in ReactQuery. In der modernen Front-End-Entwicklung müssen wir häufig mit der Back-End-Datenbank interagieren, um Daten zum Rendern der Seite zu erhalten. Allerdings können häufige Datenbankabfragen zu Leistungsproblemen führen, insbesondere wenn die Seite große Datenmengen rendern muss. In diesem Fall können wir ReactQuery verwenden, um die Front-End-Leistung von Datenbankabfragen zu optimieren. ReactQuery ist ein JavaScr zum Verwalten von Datenabfragen und -status

PHP High Performance: So optimieren Sie Datenbankabfragen PHP High Performance: So optimieren Sie Datenbankabfragen Jun 04, 2023 am 08:40 AM

Im aktuellen Internetzeitalter sind Datenbanken mit dem explosionsartigen Wachstum der Daten zum Kern eines Dienstes geworden. Die Leistung und Geschwindigkeit der Datenbank wirken sich direkt auf die Benutzererfahrung und Benutzerfreundlichkeit der Website und ihrer Anwendungen aus. Daher ist die Optimierung von Datenbankabfragen ein Thema, auf das sich Entwickler konzentrieren müssen. In der PHP-Sprache kann durch die Optimierung von Datenbankabfrageanweisungen die Leistung des Programms verbessert, die Belastung des Servers verringert und die Stabilität des Dienstes verbessert werden. In diesem Artikel wird erläutert, wie Datenbankabfragen unter folgenden Aspekten optimiert werden: 1. Verwendung von Indizes bei der Durchführung von Abfragen

See all articles