我正在使用servlet和mysql的应用程序.我想创建一个能够创建应用程序将使用的数据库的.jar文件.这只会执行一次,以便创建数据库.我在访问数据库方面没有问题,做这样的事情:Class.forName(com.mysql.jdbc.Driver)....
我正在使用servlet和mysql的应用程序.
我想创建一个能够创建应用程序将使用的数据库的.jar文件.这只会执行一次,以便创建数据库.
我在访问数据库方面没有问题,做这样的事情:
Class.forName("com.mysql.jdbc.Driver").newInstance();
Connection conexion = (Connection)DriverManager.getConnection("jdbc:mysql://localhost/test","admin","admin");
if (!conexion.isClosed())
{
Statement st = (Statement) conexion.createStatement();
ResultSet rs = st.executeQuery("select * from table_name" );
}
conexion.close();
这没关系,但我需要做的是从java类创建一个新的数据库(及其表),这可能吗?
谢谢
我正在尝试这个:
Class.forName("com.mysql.jdbc.Driver").newInstance();
Connection conexion = (Connection)DriverManager.getConnection("jdbc:mysql://localhost/mysql","admin","admin");
Statement st = (Statement) conexion.createStatement();
st.executeUpdate("CREATE DATABASE hrapp");
但我收到以下错误:
线程“main”中的异常com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException:用户’admin’@’localhost’拒绝访问数据库’hrapp’
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)
在com.mysql.jdbc.Util.handleNewInstance(Util.java:406)
在com.mysql.jdbc.Util.getInstance(Util.java:381)
在com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1030)
在com.mysql.jdbc.SQLError.createSQLException(SQLError.java:956)
在com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3491)
在com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3423)
在com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1936)
在com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2060)
在com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2536)
在com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1564)
在com.mysql.jdbc.StatementImpl.executeUpdate(StatementImpl.java:1485)
在BaseDatosSetup.BaseDatosSetup.main(BaseDatosSetup.java:18)
我通过向用户授予创建操作来解决它.我不知道为什么,我是以管理员身份做的.
解决方法:
W3CSchools.com – SQL CREATE DATABASE Statement.你不会使用executeQuery.而是使用executeUpdate.
Here就是一个简单的例子.
正如其他用户所提到的,您可能不希望从代码中创建数据库.这不是一个好习惯.
本文标题为:使用java类创建数据库
基础教程推荐
- java – 在数据库中使用foreach进行多次插入是一个好习惯吗? 2023-11-07
- MyBatis-Plus找不到Mapper.xml文件的几种解决方法 2023-02-10
- 浅谈java类和对象 2022-11-29
- Java SpringBoot集成文件之如何使用POI导出Word文档 2023-03-22
- SpringBoot返回对象时,如何将Long类型转换为String 2023-01-08
- Java利用Strategy模式实现堆排序 2023-06-02
- spring.datasource.schema配置详解 2022-11-29
- Tomcat启动成功访问主页失败的原因解决方案 2023-07-31
- Java实现分布式系统限流 2023-04-12
- 一文搞懂Spring中的Bean作用域 2022-12-03