Rumah pangkalan data tutorial mysql SQL SERVER的锁机制(一)概述(锁的种类与范围)

SQL SERVER的锁机制(一)概述(锁的种类与范围)

Jun 07, 2016 pm 05:44 PM
server mekanisme Gambaran keseluruhan taip skop

SQL SERVER的锁机制系列: SQL SERVER的锁机制(一)概述(锁的种类与范围) SQL SERVER的锁机制(二)概述(锁的兼容性与可以锁定的资源) SQL SERVER的锁机制(三)概述(锁与事务隔离级别) SQL SERVER的锁机制(四)概述(各种事务隔离级别发生的影响)

SQL SERVER的锁机制系列:

 SQL SERVER的锁机制(一)——概述(锁的种类与范围)

 SQL SERVER的锁机制(二)——概述(锁的兼容性与可以锁定的资源)

 SQL SERVER的锁机制(三)——概述(锁与事务隔离级别)

SQL SERVER的锁机制(四)——概述(各种事务隔离级别发生的影响)

 

 

锁定:通俗的讲就是加锁。锁定是 Microsoft SQL Server 数据库引擎用来同步多个用户同时对同一个数据块的访问的一种机制。

定义:当有事务操作时,香港虚拟主机,数据库引擎会要求不同类型的锁定,如相关数据行、数据页或是整个数据表,当锁定运行时,会阻止其他事务对已经锁定的数据行、数据页或数据表进行操作。只有在当前事务对于自己锁定的资源不在需要时,才会释放其锁定的资源,供其他事务使用。

一、锁的种类与范围(如下表)

锁类型

说明

共享 (S)

用于不更改或不更新数据的读取操作,如 SELECT 语句。

更新 (U)

用于可更新的资源中。 防止当多个会话在读取、锁定以及随后可能进行的资源更新时发生常见形式的死锁。

独占(也可称排他)(X)

意向

架构

大容量更新 (BU)

在向表进行大容量数据复制且指定了 TABLOCK 提示时使用。

键范围

当使用可序列化事务隔离级别时保护查询读取的行的范围。 确保再次运行查询时其他事务无法插入符合可序列化事务的查询的行。

 

 

(一)共享锁

或无法获取,就必须等待别人释放对该记录中某几种与共享锁互斥的锁,才能在设置共享锁之后,获取该条记录。

 

(二)更新锁

更新锁是一种中继锁。当同一项资源从原来的查询操作转换为更新操作时,锁定机制会从共享锁变为更新锁,再进一步变成独占锁。

独占锁(独占锁(独占锁(锁),并且每个事务都等待另一个事务释放共享模式锁,因此发生死锁。

独占锁(锁)。

),一定会先查找记录,在查找的过程中就会对相关的记录放置共享锁,等找到相应的记录之后,SQL SERVER 会先对记录放置更新锁,以避免发生死锁。因为共享锁与更新锁并不互斥,如果两个人同时对同一条记录放置共享锁,先进行更新的人,可以在别人也对同一条记录放置了共享锁时,继续放置更新锁,但因为更新锁互斥,所以当另一个人想再放置更新锁时,将无法设置,而进入停止等待状态。

 

(三)独占锁(也可称为排他锁)

, 语句在执行所需的操作之前首先执行读取操作以获取数据。 因此,需先对所在的资源放置独占锁,以确保以上操作未完成时,香港虚拟主机,不受到干扰,独占锁在开启事务之后,一直保留到事务结束。例如,

(四)意向锁

在记录上放置共享锁之前,需要对存放该记录的更大范围(如数据页或数据表)上设置意向锁,以避免其他连接对该页放置独占锁。

意向锁有两种用途:

· 防止其他事务以会使较低级别的锁无效的方式修改较高级别资源。

· 提高数据库引擎在较高的粒度级别检测锁冲突的效率。

请求共享意向锁,以防止另一个事务随后在包含那一页的表上尝试放置独占锁(锁)。 意向锁可以提高性能,网站空间,因为数据库引擎仅在表级检查意向锁来确定事务是否可以安全地获取该表上的锁。 而不需要检查表中的每行或每页上的锁以确定事务是否可以锁定整个表。如下图。

 

等等。各种意向锁的说明,如下表。

锁类型

说明

意向共享 (IS)

保护针对层次结构中某些(而并非所有)低层资源请求或获取的共享锁。

意向独占 (IX)

意向独占共享 (SIX)

独占锁以及修改的行上的独占锁。 虽然每个资源在一段时间内只能有一个 

意向更新 (IU)

共享意向更新 (SIU)

更新意向排他 (UIX)

 

下面来实际举例来说明

DELAY

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Cara memasang, menyahpasang dan menetapkan semula sandaran pelayan Windows Cara memasang, menyahpasang dan menetapkan semula sandaran pelayan Windows Mar 06, 2024 am 10:37 AM

WindowsServerBackup ialah fungsi yang disertakan dengan sistem pengendalian WindowsServer, direka untuk membantu pengguna melindungi data penting dan konfigurasi sistem, serta menyediakan penyelesaian sandaran dan pemulihan yang lengkap untuk perusahaan peringkat kecil, sederhana dan perusahaan. Hanya pengguna yang menjalankan Server2022 dan lebih tinggi boleh menggunakan ciri ini. Dalam artikel ini, kami akan menerangkan cara memasang, menyahpasang atau menetapkan semula WindowsServerBackup. Cara Menetapkan Semula Sandaran Pelayan Windows Jika anda mengalami masalah dengan sandaran pelayan anda, sandaran mengambil masa terlalu lama, atau anda tidak dapat mengakses fail yang disimpan, maka anda boleh mempertimbangkan untuk menetapkan semula tetapan sandaran Pelayan Windows anda. Untuk menetapkan semula Windows

Gunakan fungsi StringBuilder.replace() java untuk menggantikan julat aksara yang ditentukan Gunakan fungsi StringBuilder.replace() java untuk menggantikan julat aksara yang ditentukan Jul 24, 2023 pm 06:12 PM

Gunakan fungsi StringBuilder.replace() java untuk menggantikan julat aksara yang ditentukan Dalam Java, kelas StringBuilder menyediakan kaedah replace(), yang boleh digunakan untuk menggantikan julat aksara yang ditentukan dalam rentetan. Sintaks kaedah ini adalah seperti berikut: publicStringBuilderreplace(intstart,intend,Stringstr) Kaedah di atas digunakan untuk menggantikan bintang indeks daripada

Cari nombor yang tidak boleh dibahagikan dengan mana-mana nombor dalam julat, menggunakan C++ Cari nombor yang tidak boleh dibahagikan dengan mana-mana nombor dalam julat, menggunakan C++ Sep 13, 2023 pm 09:21 PM

Dalam artikel ini, kita akan membincangkan masalah mencari nombor antara 1 dan n (diberi) yang tidak boleh dibahagikan dengan sebarang nombor antara 2 dan 10. Mari kita fahami ini dengan beberapa contoh - Input:num=14Output:3Penjelasan:Terdapat tiga nombor,1,11,dan13,yang tidak boleh dibahagikan.Input:num=21Output:5Penjelasan:Terdapat nombor1,11,13,17,dan19,yang tidak boleh dibahagi jika

Versi pratonton Windows Server 2025 mengalu-alukan kemas kini, Microsoft menambah baik pengalaman ujian Insiders Versi pratonton Windows Server 2025 mengalu-alukan kemas kini, Microsoft menambah baik pengalaman ujian Insiders Feb 19, 2024 pm 02:36 PM

Sempena mengeluarkan versi Windows Server binaan 26040, Microsoft mengumumkan nama rasmi produk: Windows Server 2025. Turut dilancarkan ialah versi Windows11WindowsInsiderCanaryChannel build26040. Sesetengah rakan mungkin masih ingat bahawa bertahun-tahun yang lalu seseorang berjaya menukar Windows NT daripada mod stesen kerja kepada mod pelayan, menunjukkan persamaan antara pelbagai versi sistem pengendalian Microsoft. Walaupun terdapat perbezaan yang jelas antara versi semasa sistem pengendalian pelayan Microsoft dan Windows 11, mereka yang memberi perhatian kepada butiran mungkin tertanya-tanya: mengapa Windows Server mengemas kini jenama,

Bagaimana untuk melaksanakan pemilih julat tarikh dalam Vue? Bagaimana untuk melaksanakan pemilih julat tarikh dalam Vue? Jun 25, 2023 am 08:41 AM

Bagaimana untuk melaksanakan pemilih julat tarikh dalam Vue? Pemilih julat tarikh ialah komponen antara muka yang sering digunakan dalam aplikasi web moden. Ia membolehkan pengguna memilih tarikh atau tempoh masa daripada julat tarikh. Untuk pembangunan aplikasi web yang memerlukan pemilih julat tarikh, Vue.js ialah pilihan yang sangat baik. Vue.js ialah rangka kerja JavaScript yang progresif untuk membina antara muka pengguna Ia membolehkan pembangun membina antara muka interaktif yang kompleks menggunakan komponenisasi.

Gambaran keseluruhan masalah pembebanan operator dan penyelesaian dalam C++ Gambaran keseluruhan masalah pembebanan operator dan penyelesaian dalam C++ Oct 08, 2023 pm 01:02 PM

Gambaran Keseluruhan Masalah dan Penyelesaian Lebih Muatan Operator dalam C++ Pengenalan: Lebih muatan operator ialah ciri penting bahasa C++, yang membolehkan pengaturcara menyesuaikan operator sedia ada untuk mengendalikan jenis data tersuai. Walau bagaimanapun, beban berlebihan pengendali perlu digunakan dengan berhati-hati, kerana jika digunakan secara tidak wajar atau berlebihan, ia akan membawa kepada masalah seperti kebolehbacaan kod yang berkurangan, kekaburan dan kecekapan yang berkurangan. Artikel ini akan menggariskan masalah biasa dengan operator terlebih muatan dalam C++ dan menyediakan penyelesaian yang sepadan serta contoh kod. 1. Masalah dengan operator lebih muatan 1.1 Masalah kesamaran dalam operator lebih muatan

Penerokaan mendalam tentang lokasi penyimpanan dan mekanisme pembolehubah Golang Penerokaan mendalam tentang lokasi penyimpanan dan mekanisme pembolehubah Golang Feb 28, 2024 pm 09:45 PM

Tajuk: Penerokaan mendalam tentang lokasi storan dan mekanisme pembolehubah Golang Memandangkan aplikasi bahasa Go (Golang) semakin meningkat dalam bidang pengkomputeran awan, data besar dan kecerdasan buatan, adalah penting untuk mempunyai in- pemahaman mendalam tentang lokasi penyimpanan dan mekanisme pembolehubah Golang. Dalam artikel ini, kita akan membincangkan secara terperinci peruntukan memori, lokasi penyimpanan dan mekanisme berkaitan pembolehubah di Golang. Melalui contoh kod khusus, ia membantu pembaca lebih memahami cara pembolehubah Golang disimpan dan diurus dalam ingatan. 1.Memori pembolehubah Golang

Python Tkinter menunjukkan kuasanya: Cipta aplikasi GUI yang menakjubkan Python Tkinter menunjukkan kuasanya: Cipta aplikasi GUI yang menakjubkan Mar 24, 2024 am 09:11 AM

Tkinter ialah perpustakaan GUI yang berkuasa dalam python yang boleh digunakan untuk membuat aplikasi desktop merentas platform. Dengan kemudahan penggunaan dan pelbagai ciri, ia menyediakan pelbagai alatan untuk membina antara muka pengguna, mengendalikan acara dan mengurus susun atur. Mencipta Tetingkap GUI Untuk mencipta tetingkap GUI, anda perlu menggunakan kaedah Tkinter.Tk(). Kaedah ini mengembalikan objek Tk() yang mewakili tetingkap utama aplikasi. Tetingkap boleh mempunyai tajuk menggunakan kaedah title() dan saiz dan kedudukan tetingkap menggunakan kaedah geometri(). importtkinterastkroot=tk.Tk()root.title("Aplikasi Tkinter pertama saya")root.g

See all articles