Rumah > pangkalan data > tutorial mysql > Bagaimanakah Saya Boleh Memadankan Rentetan Dengan Cekap Bermula dengan '00' dan Digit Ketiga Bukan Sifar dalam PostgreSQL?

Bagaimanakah Saya Boleh Memadankan Rentetan Dengan Cekap Bermula dengan '00' dan Digit Ketiga Bukan Sifar dalam PostgreSQL?

Barbara Streisand
Lepaskan: 2024-12-25 06:40:26
asal
702 orang telah melayarinya

How Can I Efficiently Match Strings Starting with

Ungkapan Biasa dalam Klausa SEPERTI PostgreSQL

Ungkapan anda bertujuan untuk memadankan rentetan bermula dengan '00' dan diikuti dengan digit antara 1 dan 9, tetapi tidak termasuk rentetan dengan aksara ketiga ialah '0'. Ungkapan yang salah ialah:

select * from table where value like '00[1-9]%'
Salin selepas log masuk

Penggunaan Operator LIKE yang salah:

Pengendali ungkapan biasa dalam PostgreSQL menggunakan tilde (~) dan bukannya LIKE. Untuk menggunakan ungkapan kurungan, anda perlu menukar operator kepada ~.

Reex Diperbaiki:

SELECT *
FROM   table
WHERE  value ~ '^00[^0]'
Salin selepas log masuk
  • ^: Padan dengan permulaan rentetan

Penggunaan alternatif LIKE:

Daripada ungkapan biasa, anda boleh menggunakan operator LIKE digabungkan dengan penolakan:

SELECT *
FROM   table
WHERE  value LIKE '00%'       -- Starts with '00'
AND    value NOT LIKE '000%'  -- Excludes third character '0'
Salin selepas log masuk

Pendekatan ini selalunya lebih pantas daripada ungkapan biasa untuk corak ringkas.

Pengoptimuman Indeks:

Postgres menyokong indeks untuk ungkapan LIKE berlabuh kiri seperti '00%'. Pengindeksan boleh meningkatkan prestasi dengan ketara pada jadual besar. Ungkapan biasa mungkin tidak selalu menggunakan indeks, jadi anda perlu mempertimbangkan alternatif LIKE untuk peluang pengindeksan yang lebih baik.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Memadankan Rentetan Dengan Cekap Bermula dengan '00' dan Digit Ketiga Bukan Sifar dalam PostgreSQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan