1. Konsep tahap pengasingan
Mengapa kita perlu mempertimbangkan tahap pengasingan?
Kerana urus niaga mesti dilaksanakan serentak, dan pelaksanaan serentak mungkin menyebabkan beberapa masalah: bacaan kotor, bacaan tidak boleh berulang dan bacaan maya tidak dibenarkan berlaku , Terdapat tahap pengasingan yang berbeza untuk tahap kawalan serentak yang berbeza ini yang muncul atau tidak berlaku.
Empat tahap pengasingan yang disokong oleh MySQL ialah:
TRANSACTION_READ_UNCOMMITTED: Uncommitted read. Ini bermakna transaksi A boleh melihat perubahan transaksi B sebelum melakukan. Dengan cara ini, data kotor dibaca dan bacaan tidak berulang dan bacaan hantu dibenarkan.
TRANSACTION_READ_COMMITTED: Committed read (oracle lalai), menunjukkan bahawa membaca data tanpa komitmen adalah tidak dibenarkan (untuk mengelakkan bacaan kotor). Bacaan tidak boleh berulang dan bacaan hantu masih dibenarkan berlaku pada tahap ini.
TRANSACTION_REPEATABLE_READ: Repeatable read (MySQL default), menunjukkan bahawa transaksi dijamin dapat membaca data yang sama semula tanpa kegagalan, walaupun transaksi lain berubah data ini Walaupun anda menukarnya, anda tidak akan melihat perbezaan dalam data dua pertanyaan sebelum dan selepas. Tetapi bacaan hantu masih berlaku.
TRANSACTION_SERIALIZABLE: Serialization, ialah tahap pengasingan transaksi tertinggi, yang menghalang bacaan kotor, bacaan tidak berulang dan bacaan hantu. Pelaksanaan bersiri adalah bersamaan dengan operasi satu-benang, dengan keupayaan serentak terendah.
Nota:
Semakin tinggi tahap pengasingan transaksi, semakin kurang prestasi yang diperlukan untuk mengelakkan konflik Lebih banyak, lebih rendah kecekapan. Pada peringkat "bacaan boleh berulang", ia sebenarnya boleh menyelesaikan sebahagian daripada masalah bacaan maya, tetapi ia tidak dapat menghalang masalah bacaan maya yang disebabkan oleh kemas kini kemas kini Untuk melarang berlakunya bacaan maya, anda masih perlu menetapkan tahap pengasingan bersiri.
Pelanggan MySQL berfungsi pada tahap baca berulang secara lalai:
2. Uji tahap pengasingan TRANSACTION_READ_UNCOMMITTED
Jika klien A kembali pada masa ini, umur zhangsan dalam pangkalan data dipulihkan kepada 20. Pada masa ini, sudah terlambat, kerana pelanggan B sudah mengambil 21. Berniaga.
Kedua-dua pelanggan menarik balik dan meninggalkan pengubahsuaian pada data yang dibuat oleh transaksi semasa, dan umur zhangsan dipulihkan kepada 20
3. Uji tahap pengasingan TRANSACTION_READ_COMMITTED
Oleh kerana tahap pengasingan bacaan komited ditetapkan, tiada bacaan kotor berlaku dalam transaksi B . Ini Ia dilaksanakan oleh pelbagai mekanisme kunci dan kawalan versi MVCC bagi konkurensi transaksi.
Di bawah tahap pengasingan komited baca, menanyakan data komited boleh menyebabkan bacaan tidak boleh berulang berlaku, yang dibenarkan. Memandangkan bacaan tidak boleh berulang telah berlaku, bacaan hantu pasti boleh berlaku.
4. Uji tahap pengasingan TRANSACTION_REPEATABLE_READ
Dalam erti kata tertentu, bacaan berulang boleh mengelakkan bacaan hantu Muncul. Kerana tahap pengasingan bacaan boleh berulang semasa menghalang operasi sisipan. Walaupun tahap pengasingan bacaan boleh berulang boleh menghalang operasi memasukkan dan memadam, ia tidak boleh menghalang operasi kemas kini.
Malah, transaksi A telah dimasukkan dan dilakukan, aaa sudah wujud, kerana transaksi B mengemas kini umur aaa berjaya
Apabila pertanyaan yang sama sebelum dan selepas Apabila dilaksanakan dua kali, jika jumlah data berbeza, bacaan hantu akan berlaku. Untuk menyelesaikan sepenuhnya masalah bacaan hantu, ia tidak boleh dicapai di bawah tahap pengasingan bacaan yang boleh diulang Tahap pengasingan mesti dinaikkan kepada siri
5. Uji tahap pengasingan TRANSACTION_SERIALIZABLE
Berdasarkan fenomena, siri boleh menyelesaikan bacaan hantu Apabila membuat pertanyaan dalam keadaan yang sama, memasukkan data ke dalam jadual lain akan disekat Memandangkan transaksi B sedang membaca data, ini Apabila transaksi A menulis data sekali lagi, ia disekat (dilaksanakan dengan kunci baca-tulis, yang membenarkan membaca dan membaca, tetapi tidak membenarkan membaca dan menulis atau menulis)
Pelayan MySQL tidak akan membiarkan urutan transaksinya sendiri disekat selama-lamanya , mengakibatkan semasa Kunci yang diduduki oleh benang tidak boleh dilepaskan, dan benang lain yang melaksanakan urus niaga tidak boleh mendapatkan kunci dan disekat selama-lamanya. Jika utas yang melaksanakan transaksi menunggu terlalu lama, mekanisme tamat masa akan dicetuskan, menyebabkan utas itu melepaskan kunci dan mengembalikan ralat
Atas ialah kandungan terperinci Apakah tahap pengasingan transaksi MySQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

MySQL sesuai untuk pemula untuk mempelajari kemahiran pangkalan data. 1. Pasang alat pelayan dan klien MySQL. 2. Memahami pertanyaan SQL asas, seperti SELECT. 3. Operasi data induk: Buat jadual, masukkan, kemas kini, dan padam data. 4. Belajar Kemahiran Lanjutan: Fungsi Subquery dan Window. 5. Debugging dan Pengoptimuman: Semak sintaks, gunakan indeks, elakkan pilih*, dan gunakan had.

MySQL dengan cekap menguruskan data berstruktur melalui struktur jadual dan pertanyaan SQL, dan melaksanakan hubungan antara meja melalui kunci asing. 1. Tentukan format data dan taip apabila membuat jadual. 2. Gunakan kunci asing untuk mewujudkan hubungan antara jadual. 3. Meningkatkan prestasi melalui pengindeksan dan pengoptimuman pertanyaan. 4. Secara kerap sandaran dan memantau pangkalan data untuk memastikan pengoptimuman keselamatan data dan prestasi.

MySQL adalah sistem pengurusan pangkalan data sumber terbuka yang digunakan secara meluas dalam pembangunan web. Ciri -ciri utamanya termasuk: 1. Menyokong pelbagai enjin penyimpanan, seperti InnoDB dan Myisam, sesuai untuk senario yang berbeza; 2. Menyediakan fungsi replikasi master-hamba untuk memudahkan pengimbangan beban dan sandaran data; 3. Meningkatkan kecekapan pertanyaan melalui pengoptimuman pertanyaan dan penggunaan indeks.

SQL digunakan untuk berinteraksi dengan pangkalan data MySQL untuk merealisasikan penambahan data, penghapusan, pengubahsuaian, pemeriksaan dan reka bentuk pangkalan data. 1) SQL Melaksanakan operasi data melalui Pilih, Masukkan, Kemas kini, Padam Penyataan; 2) Gunakan pernyataan membuat, mengubah, drop untuk reka bentuk dan pengurusan pangkalan data; 3) Pertanyaan kompleks dan analisis data dilaksanakan melalui SQL untuk meningkatkan kecekapan membuat keputusan perniagaan.

Operasi asas MySQL termasuk membuat pangkalan data, jadual, dan menggunakan SQL untuk melakukan operasi CRUD pada data. 1. Buat pangkalan data: createdatabasemy_first_db; 2. Buat Jadual: CreateTableBooks (Idintauto_IncrementPrimaryKey, Titlevarchar (100) NotNull, Authorvarchar (100) NotNull, Published_yearint); 3. Masukkan Data: InsertIntoBooks (Tajuk, Pengarang, Published_year) VA

Peranan utama MySQL dalam aplikasi web adalah untuk menyimpan dan mengurus data. 1.MYSQL dengan cekap memproses maklumat pengguna, katalog produk, rekod urus niaga dan data lain. 2. Melalui pertanyaan SQL, pemaju boleh mengekstrak maklumat dari pangkalan data untuk menghasilkan kandungan dinamik. 3.MYSQL berfungsi berdasarkan model klien-pelayan untuk memastikan kelajuan pertanyaan yang boleh diterima.

Langkah -langkah untuk membina pangkalan data MySQL termasuk: 1. Buat pangkalan data dan jadual, 2. Masukkan data, dan 3. Pertama, gunakan pernyataan CreatedataBase dan createtable untuk membuat pangkalan data dan jadual, kemudian gunakan pernyataan InsertInto untuk memasukkan data, dan akhirnya gunakan pernyataan PILIH untuk menanyakan data.

MySQL sesuai untuk pemula kerana mudah digunakan dan berkuasa. 1.MYSQL adalah pangkalan data relasi, dan menggunakan SQL untuk operasi CRUD. 2. Ia mudah dipasang dan memerlukan kata laluan pengguna root untuk dikonfigurasi. 3. Gunakan Masukkan, Kemas kini, Padam, dan Pilih untuk Melaksanakan Operasi Data. 4. Orderby, di mana dan menyertai boleh digunakan untuk pertanyaan yang kompleks. 5. Debugging memerlukan memeriksa sintaks dan gunakan Jelaskan untuk menganalisis pertanyaan. 6. Cadangan pengoptimuman termasuk menggunakan indeks, memilih jenis data yang betul dan tabiat pengaturcaraan yang baik.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.