Gunakan pembolehubah nama jadual dalam Penyata Disediakan INSERT
Apabila membina satu siri pertanyaan INSERT berkelompok menggunakan objek Java PreparedStatement, ramai pembangun menghadapi cabaran untuk menambah pembolehubah nama jadual pada pertanyaan. Ini selalunya diingini apabila bekerja dengan berbilang jadual dengan format lajur yang sama.
Cuba untuk mengekodkan nama jadual menjadi "?" dalam pernyataan pertanyaan boleh menyebabkan ralat. Sebaliknya, nama jadual hendaklah disimpan sebagai pembolehubah dan diisi secara dinamik sebelum melaksanakan pertanyaan kelompok.
Sesetengah orang mungkin cuba menggunakan stmt.setString(1, "tableName1") untuk menetapkan nama jadual secara dinamik, tetapi ini tidak boleh dilakukan dalam PreparedStatement. Sebaliknya, pertanyaan dan nama jadual mesti digabungkan atau diformatkan bersama-sama sebelum ia diberikan kepada PreparedStatement.
Penyelesaian:
Anda boleh membina pertanyaan SQL secara dinamik menggunakan penggabungan rentetan atau kaedah String.format. Nama jadual tidak bertujuan untuk menjadi pembolehubah dalam PreparedStatement, tetapi merupakan sebahagian daripada rentetan pertanyaan statik.
Contoh:
<code class="language-java">String tableName = "tableName1"; // 将表名连接到查询中 String query = String.format("INSERT INTO %s (col1, col2, col3, col4, col5) VALUES (?,?,?,?,?,?);", tableName); PreparedStatement stmt = connection.prepareStatement(query);</code>
Dengan membina rentetan pertanyaan secara dinamik sebelum memberikannya kepada PreparedStatement, anda memastikan bahawa setiap penyata sisipan dihalakan ke jadual yang sesuai.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menggunakan Pembolehubah Nama Jadual dalam Pertanyaan INSERT Pernyataan yang Disediakan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!