


Mengapa Aplikasi Java Saya Membuang Pengecualian MySQLSyntaxError Apabila Memasukkan Data?
JDBC Reporting MySQLSyntaxError Exception with Valid Statement
Dalam aplikasi Java yang menyambung ke pangkalan data MySQL, pengecualian ditemui semasa cuba memasukkan yang baharu baris ke dalam jadual. Pengecualian MySQLSyntaxError telah dilemparkan, walaupun kenyataan INSERT berjaya dilaksanakan apabila menggunakan MySQL Workbench.
Kod yang disediakan ialah:
<code class="java">public static boolean aggiungiElem(String nome, GrafoGenerico g){ //... PreparedStatement sInserim=conn.prepareStatement(sqlCommandInserim); sInserim.setString(1, utente); sInserim.setString(2, nome); //sInserim.setObject(3,g); System.out.println(sInserim.toString()); sInserim.executeUpdate(sqlCommandInserim); sInserim.close(); return true; //... }</code>
Surih tindanan pengecualian mendedahkan perkara berikut:
com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '? , ? , DEFAULT , NULL )' at line 1
Sebab
Ralat menunjukkan bahawa terdapat isu sintaks dalam pernyataan INSERT. Walau bagaimanapun, apabila disemak, kenyataan itu nampaknya sah.
Penyelesaian
Isunya terletak pada baris:
<code class="java">sInserim.executeUpdate(sqlCommandInserim);</code>
Barisan ini cuba untuk melaksanakan rentetan SQL mentah berbanding dengan melaksanakan PreparedStatement dengan nilai yang ditetapkan. Kaedah yang betul untuk melaksanakan PreparedStatement ialah:
<code class="java">sInserim.executeUpdate();</code>
Pertimbangan Tambahan
Selain daripada isu khusus ini, adalah penting untuk ambil perhatian bahawa kebocoran sumber boleh berlaku jika PreparedStatements tidak ditutup dengan betul. Untuk mengelakkan ini, adalah disyorkan untuk menggunakan blok akhirnya untuk menutup PreparedStatement bersama-sama dengan sumber lain seperti Connection, Statement dan ResultSet.
Atas ialah kandungan terperinci Mengapa Aplikasi Java Saya Membuang Pengecualian MySQLSyntaxError Apabila Memasukkan Data?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Kurangkan penggunaan memori MySQL di Docker

Bagaimana anda mengubah jadual di MySQL menggunakan pernyataan Alter Table?

Cara menyelesaikan masalah MySQL tidak dapat membuka perpustakaan bersama

Jalankan MySQL di Linux (dengan/tanpa bekas podman dengan phpmyadmin)

Apa itu SQLite? Gambaran Keseluruhan Komprehensif

Menjalankan Pelbagai Versi MySQL di MacOS: Panduan Langkah demi Langkah

Bagaimana saya mengkonfigurasi penyulitan SSL/TLS untuk sambungan MySQL?

Apakah beberapa alat GUI MySQL yang popular (mis., MySQL Workbench, phpmyadmin)?
