2012-02-23 4 views
0

私は現在、Javaメモアプリケーションである学校用のプロジェクトに取り組んでいます。これは、アプリケーションに対するモデルビューコントローラのアプローチで実行されるため、それぞれが特定のタスクを処理する多くのファイルがあります。 createMemosクラスを実行すると、SQL構文エラーが発生します。それは次のように読んで....あなたは構文ミスを見ますか?MySQL構文エラーJavaメモアプリケーション

run: 
Model used mysql 
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 ')' at line 1 
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39) 
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) 
at java.lang.reflect.Constructor.newInstance(Constructor.java:513) 
at com.mysql.jdbc.Util.handleNewInstance(Util.java:409) 
at com.mysql.jdbc.Util.getInstance(Util.java:384) 
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1054) 
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3566) 
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3498) 
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1959) 
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2113) 
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2562) 
at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1664) 
at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1583) 
at models.Memos.createTable(Memos.java:49) 
at guimemos.CreateMemos.main(CreateMemos.java:15) 
BUILD SUCCESSFUL (total time: 1 second) 

私のメモクラスは以下の通りです。 。ここ

public class Memos { 

    private String table = "memos"; 
    private String props_file = "models" + java.io.File.separator + table + ".properties"; 
    private DB db; 

    public Memos() throws Exception { 
     db = new DB(); 
    } 

    public void createTable() throws Exception { 

     Properties table_props = Util.loadFile(props_file); 

     String property = DB.getModel() + "." + table; 
     String table_def = table_props.getProperty(property); 
     if (table_def == null) { 
      throw new Exception("no such property: " + property); 
     } 
     Connection cx = db.connect(); 

     String sql_op; 
     Statement st = cx.createStatement(); 

     sql_op = "drop table if exists " + table; 
     st.executeUpdate(sql_op); 

     sql_op = "create table " + table + "(" + table_def + ")"; 

     st.executeUpdate(sql_op); 
    } 

    public int insert(Memo memo) throws Exception { 
     Connection cx = db.connect(); 

     PreparedStatement st = cx.prepareStatement(
       "insert into " + table + "(title,timeStamp,content) values (?, ?, ?)"); 
     st.setString(1, memo.getTitle()); 
     st.setTimestamp(2, memo.getTimeStamp()); 
     // st.setString(2, memo.getTimeStamp().toString()); 
     st.setString(3, memo.getContent()); 
     st.executeUpdate(); 

     st = cx.prepareStatement("select max(id) from " + table); 
     ResultSet rs = st.executeQuery(); 
     rs.next(); 
     int new_id = rs.getInt(1); 
     return new_id; 
    } 

    // fetch all memos 
    public List<Memo> fetchAll() throws Exception { 
     Connection cx = db.connect(); 

     String sql_op = "select * from " + table; 
     Statement st = cx.createStatement(); 

     ResultSet rs = st.executeQuery(sql_op); 

     List<Memo> L = new LinkedList<Memo>(); 
     while (rs.next()) { 
      int id = rs.getInt("id"); 
      String title = rs.getString("title"); 
      String content = rs.getString("content"); 
      Timestamp timeStamp = rs.getTimestamp("timeStamp"); 



      Memo memo = new Memo(id, title, timeStamp, content); 
      L.add(memo); 
     } 
     return L; 
    } 

    // fetch one memo 
    public Memo fetch(int id) throws Exception { 
     Connection cx = db.connect(); 
     PreparedStatement st = cx.prepareStatement(
       "select * from " + table + " where id=?"); 
     st.setInt(1, id); 
     ResultSet rs = st.executeQuery(); 
     if (!rs.next()) { 
      return null; 
     } 
     String title = rs.getString("title"); 
     String content = rs.getString("content"); 
     Timestamp timeStamp = rs.getTimestamp("timeStamp"); 


     Memo memo = new Memo(id, title, timeStamp, content); 
     return memo; 
    } 

    // remove one memo 
    public boolean remove(int id) throws Exception { 
     Connection cx = db.connect(); 
     PreparedStatement st = cx.prepareStatement(
       "delete from " + table + " where id=?"); 
     st.setInt(1, id); 
     int num = st.executeUpdate(); 
     return (num != 0); 
    } 

    // update one memo 
    public void modify(Memo memo) throws Exception { 
     Connection cx = db.connect(); 

     int id = memo.getId(); 

     PreparedStatement st = cx.prepareStatement("update " + table 
       + " set title=?, timeStamp=?, content=?" + " where id=?"); 

     st.setString(1, memo.getTitle()); 
     st.setTimestamp(2, memo.getTimeStamp()); 
     st.setString(3, memo.getContent()); 
     st.setInt(4, id); 
     st.executeUpdate(); 
    } 
} 

プロパティファイルです:

sql_op = "create table " + table + "(" + table_def + ")"; 
st.executeUpdate(sql_op); 

:何かがこの文でtable_defと間違っているよう

mysql.memos=id integer auto_increment primary key not null,\ 
title varchar(80) not null, 
timeStamp datetime not null,\ 
content text 

sqlite.memos=id integer primary key not null,\ 
title text not null,\ 
timeStamp int not null,\ 
content text 

エラーを提案

Model used mysql 
Attempting to execute SQL: drop table if exists memos 
Attempting to execute SQL: create table memos(id integer auto_increment primary key  not null,title varchar(80) not null,) 
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 ')' at line 1 
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39 ) 
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) 
at java.lang.reflect.Constructor.newInstance(Constructor.java:513) 
at com.mysql.jdbc.Util.handleNewInstance(Util.java:409) 
at com.mysql.jdbc.Util.getInstance(Util.java:384) 
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1054) 
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3566) 
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3498) 
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1959) 
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2113) 
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2562) 
at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1664) 
at com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1583) 
at models.Memos.createTable(Memos.java:50) 
at guimemos.CreateMemos.main(CreateMemos.java:15) 
+3

は、SQLは、あなたがあなたの –

+0

table_defは何を発射されているものを印刷してみますか? – Kayser

+0

ええ、私もvarに完全なSQLクエリを保存しようとすると、私たちのためにそれらを提供することはできますか? –

答えて

0

を追加した後に見えますあなたはそれをプロパティファイルから読み込むので、何が間違っているかを実際に確認する必要があります。私はこれに変更しようとしています:

sql_op = "create table " + table + "(" + table_def + ")"; 
System.out.println("Attempting to execute SQL: " + sql_op); 
st.executeUpdate(sql_op); 

出力が何であるかをお知らせください。

EDIT:

mysql.memos=id integer auto_increment primary key not null,\ 
title varchar(80) not null, 
timeStamp datetime not null,\ 
content text 

注2行目に\の欠如:問題は、このセクションです。それはあなたの財産を切り捨てるため、タイムスタンプとコンテンツの行が失われます。末尾に,があるため、構文エラーです。

はこれに変更してみてください:

mysql.memos=id integer auto_increment primary key not null,\ 
title varchar(80) not null,\ 
timeStamp datetime not null,\ 
content text 
+0

これを実行した後に受け取るエラーは、上記の私の小道具ファイルの下に掲載されます。 。 。 。それを見てください –

+0

うわーみんなダム。私の小道具のファイルを見るとバックスラッシュがありません。 。 。問題が解決しました。新しいものが生まれます。 。 。その上に掲示された –

+0

私はちょうどこのすべての私は私が作成していた変数と私はそのようなフィールドのタイムスタンプを挿入していた変数のための別の変数名を持っていた私はそれをスタンプと呼ばれる私の小道具ファイル –