Rumah > Java > javaTutorial > Bagaimana untuk Menggunakan Kad Liar dalam Penyata Disediakan dengan LIKE?

Bagaimana untuk Menggunakan Kad Liar dalam Penyata Disediakan dengan LIKE?

Linda Hamilton
Lepaskan: 2024-11-15 12:32:02
asal
892 orang telah melayarinya

How to Use Wildcards in Prepared Statements with LIKE?

Pertanyaan Wildcard dalam Penyata Disediakan dengan LIKE

Apabila menggunakan pernyataan yang disediakan untuk pertanyaan pangkalan data, melaksanakan fungsi carian dengan kata kunci selalunya memerlukan penggunaan pengendali LIKE. Panduan ini menyediakan penyelesaian yang komprehensif tentang cara untuk mencapai ini dengan pernyataan yang disediakan.

Untuk menggunakan operator LIKE dengan pernyataan yang disediakan, anda boleh menambahkan simbol kad bebas (%) pada istilah carian dalam nilai yang disediakan pada yang disediakan. pernyataan, seperti:

String notes = "keyword%";
PreparedStatement pstmt = con.prepareStatement(
      "SELECT * FROM analysis WHERE notes LIKE ?");
pstmt.setString(1, notes);
ResultSet rs = pstmt.executeQuery();
Salin selepas log masuk

Dengan menetapkan nilai dengan kad bebas yang dilampirkan, anda mendayakan pertanyaan yang sepadan dengan semua rekod di mana lajur "nota" mengandungi kata kunci input sebagai subrentetan.

Walau bagaimanapun, aksara tertentu mempunyai makna istimewa dalam SQL, termasuk %, !, [, _, dan ]. Untuk memastikan pengendalian yang betul bagi aksara ini, mereka harus dilepaskan menggunakan klausa ESCAPE dalam pernyataan yang disediakan. Contohnya:

String notes = "keyword%"
    .replace("!", "!!")
    .replace("%", "!%")
    .replace("_", "!_")
    .replace("[", "![");
PreparedStatement pstmt = con.prepareStatement(
        "SELECT * FROM analysis WHERE notes LIKE ? ESCAPE '!'");
pstmt.setString(1, notes + "%");
Salin selepas log masuk

Dengan menggantikan aksara ini dengan versi yang dilepaskan, pernyataan yang disediakan akan mentafsir kad bebas dengan betul dan memadankan rekod dengan sewajarnya.

Bergantung pada keperluan carian anda, anda boleh melaraskan peletakan kad bebas untuk mencapai senario padanan yang berbeza:

  • Padanan awalan: "%" dilampirkan pada penghujung kata kunci (cth., "kata kunci%")
  • Padanan akhiran: "%" ditambah pada permulaan kata kunci (cth., "%" "kata kunci")
  • Padanan global: "%" dilampirkan pada kedua-dua hujung kata kunci (cth., "%" "kata kunci" "%")

Atas ialah kandungan terperinci Bagaimana untuk Menggunakan Kad Liar dalam Penyata Disediakan dengan LIKE?. 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