Jadual Kandungan
0. Latar belakang cerita
1 Cara menggunakan replace into
2. Apabila terdapat indeks unik—ganti ke dalam & dan gantikan kesan
3. Apabila tiada indeks unik—ganti ke dan ganti
1) Situasi khusus bagi fungsi ganti
2) Situasi khusus .replace into function
4.replace的用法
Rumah pangkalan data tutorial mysql Mari analisa perbezaan antara replace into dan replace dalam MySQL

Mari analisa perbezaan antara replace into dan replace dalam MySQL

Aug 22, 2022 pm 05:25 PM
mysql

Artikel ini membawakan anda pengetahuan yang berkaitan tentang mysql, yang terutamanya memperkenalkan penjelasan terperinci tentang perbezaan antara replace into dan replace dalam MySQL Artikel memperkenalkannya secara terperinci melalui kod sampel, yang akan menjadi rujukan untuk kajian atau kerja semua orang. Nilai, harap ia membantu semua orang.

Mari analisa perbezaan antara replace into dan replace dalam MySQL

Pembelajaran yang disyorkan: tutorial video mysql

Artikel ini adalah pengenalan saya tidak pernah memberi perhatian kepada perbezaan antara menggantikan ke dan menggantikan sebelum ini. Selepas menguji dalam berbilang senario, saya tidak dapat menemui sebarang perbezaan penting antara keduanya apabila memasukkan data? Jika sesiapa tahu butirannya, sila tinggalkan mesej untuk memberitahu saya, saya amat berterima kasih! ! !

0. Latar belakang cerita

[Struktur jadual]

CREATE TABLE `xtp_algo_white_list` (
  `strategy_type` int DEFAULT NULL,
  `user_name` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `status` int DEFAULT NULL,
  `destroy_at` datetime DEFAULT NULL,
  `created_at` datetime DEFAULT CURRENT_TIMESTAMP,
  `updated_at` datetime DEFAULT CURRENT_TIMESTAMP,
  UNIQUE KEY `xtp_algo_white_list_UN` (`strategy_type`,`user_name`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin


# `strategy_type`,`user_name` 这两个是联合唯一索引,多关注后续需要用到!!!
Salin selepas log masuk

[Keperluan:]

  • Menurut data akaun 209133002266 dalam jadual, masukkan semula pengguna 20220302001 supaya medan strategy_type & status & destroy_at dalam data yang baru dijana adalah konsisten dengan pengguna 209133002266.
  • Menggunakan kemas kini untuk mengemas kini satu demi satu juga mungkin, tetapi ia lebih perlahan.
  • Kesan penggunaan replace into akan menjadi lebih tinggi, tetapi kajian mendalam mendapati terdapat juga beberapa perangkap

1 Cara menggunakan replace into

replace into xtp_algo_white_list (`strategy_type`, `user_name`, `status`, `destroy_at`)
select strategy_type ,20220302001, status, destroy_at from xtp_algo_white_list xawl where xawl.user_name = 209133002266;

# replace into 后面跟表格+需要插入的所有字段名(自动递增字段不用写)
# select 后面选择的字段,如果根据查询结果取值,则写字段名;如果是写死的,则直接写具体值即可
# 可以理解为,第一部分是插入表格的结构,第二部分是你查询的数据结果
Salin selepas log masuk

2. Apabila terdapat indeks unik—ganti ke dalam & dan gantikan kesan

langkah1: Pelaksanaan pertama sql

replace into xtp_algo_white_list (`strategy_type`, `user_name`, `status`, `destroy_at`)
select strategy_type ,20220302001, status, destroy_at from xtp_algo_white_list xawl where xawl.user_name = 209133002266;
Salin selepas log masuk
Salin selepas log masuk

[ Selepas pelaksanaan, hasil pertanyaan Seperti berikut: ]

langkah2: Pelaksanaan kedua sql

Mengapakah semasa pelaksanaan kedua, kemas kini 12 baris data dan dibuat pada data dikemas kini, manakala kemas kini 6 baris dipaparkan pada kali pertama? ? ?

1. Kerana apabila melaksanakan sql, replace into sebenarnya dilaksanakan dalam dua langkah. Langkah pertama ialah mengubah data pertanyaan kepada data baharu. Dalam langkah kedua, jika data baharu sudah mempunyai kandungan yang sama dalam jadual, ia akan dipadamkan. Jika tiada kandungan yang sama, data baharu akan dimasukkan terus.

2. Kerana apabila perkara di atas dilaksanakan buat kali pertama, data baharu telah dijana sekali, dan kemudian data terkini akan dimasukkan dipaparkan

langkah3 : Pelaksanaan ketiga sql

# 此时执行的是replace 

replace xtp_algo_white_list (`strategy_type`, `user_name`, `status`, `destroy_at`)
select strategy_type ,20220302001, status, destroy_at from xtp_algo_white_list xawl where xawl.user_name = 209133002266;
Salin selepas log masuk

  • Situasi terakhir yang dilihat ialah sama seperti pelaksanaan kedua sql .
  • Apabila data baharu sudah wujud, ganti ke dan ganti adalah sama
  • Selepas itu padamkan semua 20220302001, laksanakan SQL sekali dan dua kali, dan dapatkan kesan penggantian ke dan ganti adalah sama. .

[Ringkasan:] Apabila terdapat sekatan indeks yang unik, jika data baharu akan disekat oleh indeks unik, data itu hanya akan disisipkan sekali dipadam dahulu dan kemudian dimasukkan. Pada masa ini, replace into mempunyai kesan yang sama seperti replace.

3. Apabila tiada indeks unik—ganti ke dan ganti

Kami akan memadamkan indeks unik bersama strategi_jenis & nama_pengguna dan memadamkan semua data 20220302001 pengguna. Struktur jadual akhir adalah seperti berikut:

CREATE TABLE `xtp_algo_white_list` (
  `strategy_type` int DEFAULT NULL,
  `user_name` varchar(64) COLLATE utf8_bin DEFAULT NULL,
  `status` int DEFAULT NULL,
  `destroy_at` datetime DEFAULT NULL,
  `created_at` datetime DEFAULT CURRENT_TIMESTAMP,
  `updated_at` datetime DEFAULT CURRENT_TIMESTAMP
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin
Salin selepas log masuk

1) Situasi khusus bagi fungsi ganti

langkah1: Laksanakan penggantian berikut yang sepadan dengan sql:

replace xtp_algo_white_list (`strategy_type`, `user_name`, `status`, `destroy_at`)
select strategy_type ,20220302001, status, destroy_at from xtp_algo_white_list xawl where xawl.user_name = 209133002266;
Salin selepas log masuk

langkah2: Jalankan ganti semula sql yang sepadan:

  • Penggantian Pelaksanaan Kedua sepadan dengan sql Kerana tiada sekatan indeks yang unik, data asal tidak berubah. Enam keping data baharu telah dijana semula.
  • Jika sql di atas dilaksanakan kemudian, data akan terus meningkat

2) Situasi khusus .replace into function

Sebelum melaksanakan, bersihkan data , padamkan semua data 20220302001

langkah1: laksanakan penggantian berikut ke dalam sql yang sepadan:

replace into xtp_algo_white_list (`strategy_type`, `user_name`, `status`, `destroy_at`)
select strategy_type ,20220302001, status, destroy_at from xtp_algo_white_list xawl where xawl.user_name = 209133002266;
Salin selepas log masuk
Salin selepas log masuk

step2:再次执行replace into 对应sql:

最终发现,没有唯一索引的时候,replace into 与replace 居然一摸一样的效果,都是继续增加数据。

通过以上分析,没看出replace into 与replace 具体有啥区别????有谁知道呢?

4.replace的用法

  • 单独replace的作用是替换字段中某数值的显示效果。可以数值中的部分替换、也可以全部替换。
  • 如下表格,将user_name的字段,20220302改为"A_20220303"显示,并且新字段叫做new_name显示

select *, replace(user_name,20220302,'A_20220303') as "new_name" from xtp_algo_white_list where user_name = 20220302001;
Salin selepas log masuk

推荐学习:mysql视频教程

Atas ialah kandungan terperinci Mari analisa perbezaan antara replace into dan replace dalam MySQL. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
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)

MySQL: Kemudahan Pengurusan Data untuk Pemula MySQL: Kemudahan Pengurusan Data untuk Pemula Apr 09, 2025 am 12:07 AM

MySQL sesuai untuk pemula kerana mudah dipasang, kuat dan mudah untuk menguruskan data. 1. Pemasangan dan konfigurasi mudah, sesuai untuk pelbagai sistem operasi. 2. Menyokong operasi asas seperti membuat pangkalan data dan jadual, memasukkan, menanyakan, mengemas kini dan memadam data. 3. Menyediakan fungsi lanjutan seperti menyertai operasi dan subqueries. 4. Prestasi boleh ditingkatkan melalui pengindeksan, pengoptimuman pertanyaan dan pembahagian jadual. 5. Sokongan sokongan, pemulihan dan langkah keselamatan untuk memastikan keselamatan data dan konsistensi.

Bolehkah saya mengambil kata laluan pangkalan data di Navicat? Bolehkah saya mengambil kata laluan pangkalan data di Navicat? Apr 08, 2025 pm 09:51 PM

Navicat sendiri tidak menyimpan kata laluan pangkalan data, dan hanya boleh mengambil kata laluan yang disulitkan. Penyelesaian: 1. Periksa Pengurus Kata Laluan; 2. Semak fungsi "Ingat Kata Laluan" Navicat; 3. Tetapkan semula kata laluan pangkalan data; 4. Hubungi pentadbir pangkalan data.

Cara Membuat Premium Navicat Cara Membuat Premium Navicat Apr 09, 2025 am 07:09 AM

Buat pangkalan data menggunakan Navicat Premium: Sambungkan ke pelayan pangkalan data dan masukkan parameter sambungan. Klik kanan pada pelayan dan pilih Buat Pangkalan Data. Masukkan nama pangkalan data baru dan set aksara yang ditentukan dan pengumpulan. Sambung ke pangkalan data baru dan buat jadual dalam penyemak imbas objek. Klik kanan di atas meja dan pilih masukkan data untuk memasukkan data.

Cara menyalin jadual di mysql Cara menyalin jadual di mysql Apr 08, 2025 pm 07:24 PM

Menyalin jadual di MySQL memerlukan membuat jadual baru, memasukkan data, menetapkan kunci asing, menyalin indeks, pencetus, prosedur tersimpan, dan fungsi. Langkah -langkah khusus termasuk: mewujudkan jadual baru dengan struktur yang sama. Masukkan data dari jadual asal ke dalam jadual baru. Tetapkan kekangan utama asing yang sama (jika jadual asal mempunyai satu). Buat indeks yang sama. Buat pencetus yang sama (jika jadual asal mempunyai satu). Buat prosedur atau fungsi yang disimpan yang sama (jika jadual asal digunakan).

Bagaimana untuk melihat kata laluan pangkalan data di Navicat untuk MariaDB? Bagaimana untuk melihat kata laluan pangkalan data di Navicat untuk MariaDB? Apr 08, 2025 pm 09:18 PM

Navicat untuk MariaDB tidak dapat melihat kata laluan pangkalan data secara langsung kerana kata laluan disimpan dalam bentuk yang disulitkan. Untuk memastikan keselamatan pangkalan data, terdapat tiga cara untuk menetapkan semula kata laluan anda: Tetapkan semula kata laluan anda melalui Navicat dan tetapkan kata laluan yang kompleks. Lihat fail konfigurasi (tidak disyorkan, risiko tinggi). Gunakan alat baris perintah sistem (tidak disyorkan, anda perlu mahir dalam alat baris arahan).

Cara Membuat Sambungan Baru ke MySQL di Navicat Cara Membuat Sambungan Baru ke MySQL di Navicat Apr 09, 2025 am 07:21 AM

Anda boleh membuat sambungan MySQL baru di Navicat dengan mengikuti langkah -langkah: Buka aplikasi dan pilih Sambungan Baru (Ctrl N). Pilih "MySQL" sebagai jenis sambungan. Masukkan nama host/alamat IP, port, nama pengguna, dan kata laluan. (Pilihan) Konfigurasikan pilihan lanjutan. Simpan sambungan dan masukkan nama sambungan.

Cara Melaksanakan SQL di Navicat Cara Melaksanakan SQL di Navicat Apr 08, 2025 pm 11:42 PM

Langkah -langkah untuk melaksanakan SQL di Navicat: Sambungkan ke pangkalan data. Buat tetingkap editor SQL. Tulis pertanyaan SQL atau skrip. Klik butang Run untuk melaksanakan pertanyaan atau skrip. Lihat hasilnya (jika pertanyaan dilaksanakan).

Navicat tidak dapat menyambung ke MySQL/MariaDB/PostgreSQL dan pangkalan data lain Navicat tidak dapat menyambung ke MySQL/MariaDB/PostgreSQL dan pangkalan data lain Apr 08, 2025 pm 11:00 PM

Alasan Biasa Mengapa Navicat tidak dapat menyambung ke pangkalan data dan penyelesaiannya: 1. Periksa status berjalan pelayan; 2. Periksa maklumat sambungan; 3. Laraskan tetapan firewall; 4. Konfigurasi akses jauh; 5. menyelesaikan masalah rangkaian; 6. Periksa keizinan; 7. Memastikan keserasian versi; 8. menyelesaikan masalah lain.

See all articles