java - 无法使用 Java 在 MySQL 中创建表

标签 java mysql

<分区>

我遇到了一个简单的问题,但我不知道为什么。 第一个 SQL 可以创建表,第二个不能。为什么?

String temString = "create table if not exists test(number int not null, name varchar(20) not null, primary key(number))engine=myisam default charset=utf8";
String createTableString = "create table if not exists ju_users (ju_userID int not null, TaobaoID int not null, ju_userName varchar(20) not null, ju_userPWD varchar(10) not null, primary key (ju_userID)) engine=myisam defalut charset=utf8";

消息是:

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 'defalut charset=utf8' at line 1
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
    at java.lang.reflect.Constructor.newInstance(Unknown Source)
    at com.mysql.jdbc.Util.handleNewInstance(Util.java:377)
    at com.mysql.jdbc.Util.getInstance(Util.java:360)
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:978)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3887)
    at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3823)
    at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2435)
    at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2582)
    at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2530)
    at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:1907)
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2141)
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2077)
    at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2062)
    at mysql_test.Main.CreateTable(Main.java:132)
    at mysql_test.Main.main(Main.java:159)

我只想设置表的引擎...

最佳答案

你把 default 拼错了。

代替:

defalut charset=utf8"

您的查询应以

结尾
default charset=utf8"

关于java - 无法使用 Java 在 MySQL 中创建表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27632722/

相关文章:

JavaFx 和套接字监听器

MySQL : How TO Use ANY_VALUE with all the column of DB table

mysql - 替换字符串中的撇号

java - 如何在HQL中连接多个表

java - 如何在不创建新的 Java Swing 的情况下 setText

java - 使用 AES 加密和连续解密后数据不同

java - 如何从头开始为 bundle 使用 org.apache.felix.scr 注释?

php - 根据用户选择在页面上包含不同的 mysql 数据

mysql - 如何按条件执行触发器SQL?

php - 如何从 EC2 实例对 RDS 实例进行 MySQL 查询?