0

テーブルの SQLite データベースの作業を開始しました。テキストレーンを使用してデータベースに情報を保存しようとすると、このエラーが発生します。私は NetBeans を使用しています。

private void Cmd_saveActionPerformed(java.awt.event.ActionEvent evt) {                                           
   try{
      String sql = "Insert into KYaziciProg (Yapılan İşlem ,Müşteri Adı ,Ürünün Cinsi ,Ürünün Miktarı ,Ürünün Fiyatı ,Ürünün Tutarı ,İşlem Tarihi ,Ödeme Vadesi ,Yapılan Ödeme ,Kalan Bakiye) values (?,?,?,?,?,?,?,?,?,?)";

      pst=conn.prepareStatement(sql);
      pst.setString(2, jTextField2.getText());
      pst.setString(3, jTextField1.getText());
      pst.setString(4, jTextField3.getText());
      pst.setString(5, jTextField4.getText());
      pst.setString(6, jTextField5.getText());
      pst.setString(7, jTextField6.getText());
      pst.setString(8, jTextField7.getText());
      pst.setString(9, jTextField8.getText());
      pst.setString(10, jTextField9.getText());
      pst.setString(11, jTextField10.getText());

      pst.execute();

      JOptionPane.showMessageDialog(null, "Kaydedildi!");

   }   
   catch(Exception e)
   {     
      JOptionPane.showMessageDialog(null, e);   
   }  
   Update_table();
}   

これは、私がこれを取得しようとしているコードです。setString で 2 から始めました。わかりませんが、SQLite では、以前に作成したことのない列が 1 つ増えました。下の画像を参照してください 列

編集:

ボタンをクリックしたときの同じエラー。これらのエラーは実行パネルに表示されました。走る:

java.sql.SQLException: near "İşlem": syntax error
    at org.sqlite.DB.throwex(DB.java:288)
    at org.sqlite.NativeDB.prepare(Native Method)
    at org.sqlite.DB.prepare(DB.java:114)
    at org.sqlite.PrepStmt.<init>(PrepStmt.java:37)
    at org.sqlite.Conn.prepareStatement(Conn.java:231)
    at org.sqlite.Conn.prepareStatement(Conn.java:224)
    at org.sqlite.Conn.prepareStatement(Conn.java:213)
    at populatethingy.Cmd_saveActionPerformed(populatethingy.java:253)
    at populatethingy.access$300(populatethingy.java:13)
    at populatethingy$4.actionPerformed(populatethingy.java:210)
    at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:1995)
    at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2318)
    at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:387)
    at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:242)
    at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:236)
    at java.awt.Component.processMouseEvent(Component.java:6289)
    at javax.swing.JComponent.processMouseEvent(JComponent.java:3267)
    at java.awt.Component.processEvent(Component.java:6054)
    at java.awt.Container.processEvent(Container.java:2041)
    at java.awt.Component.dispatchEventImpl(Component.java:4652)
    at java.awt.Container.dispatchEventImpl(Container.java:2099)
    at java.awt.Component.dispatchEvent(Component.java:4482)
    at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4577)
    at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4238)
    at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4168)
    at java.awt.Container.dispatchEventImpl(Container.java:2085)
    at java.awt.Window.dispatchEventImpl(Window.java:2478)
    at java.awt.Component.dispatchEvent(Component.java:4482)
    at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:644)
    at java.awt.EventQueue.access$000(EventQueue.java:85)
    at java.awt.EventQueue$1.run(EventQueue.java:603)
    at java.awt.EventQueue$1.run(EventQueue.java:601)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:87)
    at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:98)
    at java.awt.EventQueue$2.run(EventQueue.java:617)
    at java.awt.EventQueue$2.run(EventQueue.java:615)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.security.AccessControlContext$1.doIntersectionPrivilege(AccessControlContext.java:87)
    at java.awt.EventQueue.dispatchEvent(EventQueue.java:614)
    at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:269)
    at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:184)
    at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:174)
    at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:169)
    at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:161)
    at java.awt.EventDispatchThread.run(EventDispatchThread.java:122)
BUILD SUCCESSFUL (total time: 3 seconds)
4

2 に答える 2

1

列にスペースが含まれているため、引用する必要があるため、次のようになります。

Insert into KYaziciProg ("Yapılan İşlem" ,"Müşteri Adı" , ...
于 2013-08-15T08:12:43.767 に答える
0

1 から開始する必要があります。列ROWIDは Sqlite によって自動生成されます。

ただし、挿入ステートメントを見ると、その列を指定していないため、その列に挿入していないため、とにかく問題にはなりません。

パラメータインデックスは?挿入ステートメントの文字に対応しているため、コードが現在ステートメントを実行しようとしている方法であるため、そのエラーが発生しています("Value from jTextFeildXこれは、値が何であれ、私のpuesdo文字列にすぎないことに注意してください.

KYaziciProg (Yapılan İşlem ,Müşteri Adı ,Ürünün Cinsi ,Ürünün Miktarı ,Ürünün Fiyatı ,Ürünün Tutarı ,İşlem Tarihi ,Ödeme Vadesi ,Yapılan Ödeme ,Kalan Bakiye) 値に挿入( ? jTextFeildX の値、jTextFeildX の値、jTextFeildX の値、jTextFeildX の値、jTextFeildX の値、jTextFeildX の値)";

クエリにまだあることに注意してください?..無効なSQLを意味します

コードを

  pst.setString(1, jTextField2.getText());
  pst.setString(2, jTextField1.getText());
  pst.setString(3, jTextField3.getText());
  pst.setString(4, jTextField4.getText());
  pst.setString(5, jTextField5.getText());
  pst.setString(6, jTextField6.getText());
  pst.setString(7, jTextField7.getText());
  pst.setString(8, jTextField8.getText());
  pst.setString(9, jTextField9.getText());
  pst.setString(10, jTextField10.getText());

編集 このコードを追加して、netbeans 出力コンソールに移動し、結果の行を質問に投稿してください。

catch(Exception e)
{  
  e.printStackTrace();    // Add this line 
  JOptionPane.showMessageDialog(null, e);   
}
于 2013-08-14T23:10:50.573 に答える