简体   繁体   English

Java MySQL ODBC PreparedStatement切断查询

[英]Java MySQL ODBC PreparedStatement cutting off query

`I am having a problem with doing a PreparedStatement for Java ODBC MySQL. `我在为Java ODBC MySQL做PreparedStatement时遇到问题。 It seems to be cutting off the query, and giving a syntax error. 它似乎切断了查询,并给出了语法错误。 I am not sure how to proceed, as I am only learning Java SQL at this point. 我不确定如何继续,因为此时我仅学习Java SQL。 I can't really do a self contained example because the problem involves databases, and it would get quite big. 我真的不能做一个独立的例子,因为问题涉及数据库,而且会变得很大。

The code with the problem is this.. 有问题的代码是这样的。

public void insertEntry(
            Hashtable<String, String> strings,
            Hashtable<String, Integer> integers,
            Date created, Date paid, boolean enabled)
            throws ClassNotFoundException, SQLException {
        Class.forName("com.mysql.jdbc.Driver");

        String dburl = "jdbc:mysql://" + dbHost + "/" + dbName +
                        "?user=" + dbUser + "&password=" + dbPass;

        connect = DriverManager.getConnection(dburl);

        ps = connect.prepareStatement("INSERT INTO " + dbName + ".users INSERT " +
                "enabled=?, username=?, created=?, paid=?, alias=?, password=?, " +
                "email=?, bitmessage=?, torchat=?, reputation=?," +
                "privacy=?, fpmport=?, fpm-template=? ;");

        java.sql.Date SQLcreated = new java.sql.Date(created.getTime());
        java.sql.Date SQLpaid = new java.sql.Date(paid.getTime());
        System.out.println("Debug: SQLpaid = " + SQLpaid.toString());

        ps.setBoolean(1, enabled);
        ps.setString(2, strings.get("username"));
        ps.setDate(3, SQLcreated);
        ps.setDate(4, SQLpaid);
        ps.setString(5, strings.get("alias"));
        ps.setString(6, strings.get("password"));
        ps.setString(7, strings.get("email"));
        ps.setString(8, strings.get("bitmessage"));
        ps.setString(9, strings.get("torchat"));
        ps.setInt(10, integers.get("reputation"));
        ps.setInt(11, integers.get("privacy"));
        ps.setInt(12, integers.get("fpmport"));
        ps.setString(13, strings.get("fpm-template"));
        ps.executeUpdate();

        ps.close();
        connect.close();
        resultSet.close();
    }

I get the following output when trying to use this method... 尝试使用此方法时,我得到以下输出...

Debug: SQLpaid = 1990-03-21
com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorEx ception: 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 'INSERT enabled=0, username='default_username', created='2000-03-21', paid='1990-' at line 1
at sun.reflect.NativeConstructorAccessorImpl.newInsta nce0(Native Method)
at sun.reflect.NativeConstructorAccessorImpl.newInsta nce(NativeConstructorAccessorImpl.java:57)
at sun.reflect.DelegatingConstructorAccessorImpl.newI nstance(DelegatingConstructorAccessorImpl.java:45)
at java.lang.reflect.Constructor.newInstance(Construc tor.java:532)
at com.mysql.jdbc.Util.handleNewInstance(Util.java:41 1)
at com.mysql.jdbc.Util.getInstance(Util.java:386)
at com.mysql.jdbc.SQLError.createSQLException(SQLErro r.java:1054)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.ja va:4237)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.ja va:4169)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:26 17)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java :2778)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionIm pl.java:2834)
at com.mysql.jdbc.PreparedStatement.executeInternal(P reparedStatement.java:2156)
at com.mysql.jdbc.PreparedStatement.executeUpdate(Pre paredStatement.java:2441)
at com.mysql.jdbc.PreparedStatement.executeUpdate(Pre paredStatement.java:2366)
at com.mysql.jdbc.PreparedStatement.executeUpdate(Pre paredStatement.java:2350)
at database.Users.insertEntry(Users.java:297)
at test.dbUsers.main(dbUsers.java:95) 

i think your doing some mistake in your code: 我认为您在代码中犯了一些错误:

these are following as: 这些如下:

1. your mention INSERT and you should must change like SET 1.您提到INSERT并且必须像SET一样更改

2. your adding the ; 2.您添加; in your SQL Query you should remove that. 在您的SQL查询中,您应该将其删除。

your code: 您的代码:

 ps = connect.prepareStatement
 ("INSERT INTO " + dbName + ".users  INSERT " #look here error to change 'set' +
  "enabled=?, username=?, created=?, paid=?, alias=?, password=?, " +
  "email=?, bitmessage=?, torchat=?, reputation=?," +
  "privacy=?, fpmport=?, fpm-template=?  ; " #remove this semicolon(;));

you should must change like as: 您应该像这样进行更改:

 ps = connect.prepareStatement
           ("INSERT INTO " + dbName + ".users SET " +
           "enabled=?, username=?, created=?, paid=?, alias=?, password=?, " +
           "email=?, bitmessage=?, torchat=?, reputation=?," +
           "privacy=?, fpmport=?, fpm-template=? ");

Change: 更改:

INSERT INTO " + dbName + ".users INSERT "

To: 至:

INSERT INTO " + dbName + ".users SET "

Refer to : 参考

MySQL: INSERT Syntax MySQL:INSERT语法

INSERT [LOW_PRIORITY | 插入[LOW_PRIORITY | DELAYED | 延迟| HIGH_PRIORITY] [IGNORE] HIGH_PRIORITY] [IGNORE]
[INTO] tbl_name [INTO] tbl_name
[PARTITION (partition_name,...)] [PARTITION(partition_name,...)]
SET col_name={expr | SET col_name = {expr | DEFAULT}, ... DEFAULT},...
[ ON DUPLICATE KEY UPDATE [关于重复键更新
col_name=expr COL_NAME = EXPR
[, col_name=expr] ... ] [,col_name = expr] ...]

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM