gpt4 book ai didi

java - 访问被拒绝,嵌入式 Derby 中的问题

转载 作者:搜寻专家 更新时间:2023-10-30 23:28:58 24 4
gpt4 key购买 nike

我的 Derby 引擎有问题。

当我创建新数据库、创建新表并插入或显示行时,一切正常。当我尝试在我的练习示例中使用数据库时,数据库工作正常,我能够从表中插入和选择数据。

代码:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.ResultSetMetaData;


public class Restaurants
{
private static String dbURL = "jdbc:derby:c:\\Apache\\db-derby-10.14.2.0-bin\\bin\\myDBExample;create=true";
private static String tableName = "restaurants";
// jdbc Connection
private static Connection conn = null;
private static Statement stmt = null;

public static void main(String[] args)
{
createConnection();
//insertRestaurants(5, "LaVals Leb", "Berkeley");
//insertRestaurants(6, "House Leb", "New York");
selectRestaurants();
shutdown();
}

private static void createConnection()
{
try
{
Class.forName("org.apache.derby.jdbc.ClientDriver").newInstance();
//Get a connection
conn = DriverManager.getConnection(dbURL);
}
catch (Exception except)
{
except.printStackTrace();
}
}

private static void insertRestaurants(int id, String restName, String cityName)
{
try
{
stmt = conn.createStatement();
stmt.execute("insert into " + tableName + " values (" +
id + ",'" + restName + "','" + cityName +"')");
stmt.close();
}
catch (SQLException sqlExcept)
{
sqlExcept.printStackTrace();
}
}

private static void selectRestaurants()
{
try
{
stmt = conn.createStatement();
ResultSet results = stmt.executeQuery("select * from " + tableName);
ResultSetMetaData rsmd = results.getMetaData();
int numberCols = rsmd.getColumnCount();
for (int i=1; i<=numberCols; i++)
{
//print Column Names
System.out.print(rsmd.getColumnLabel(i)+"\t\t");
}

System.out.println("\n-------------------------------------------------");

while(results.next())
{
int id = results.getInt(1);
String restName = results.getString(2);
String cityName = results.getString(3);
System.out.println(id + "\t\t" + restName + "\t\t" + cityName);
}
results.close();
stmt.close();
}
catch (SQLException sqlExcept)
{
sqlExcept.printStackTrace();
}
}

private static void shutdown()
{
try
{
if (stmt != null)
{
stmt.close();
}
if (conn != null)
{
DriverManager.getConnection(dbURL + ";shutdown=true");
conn.close();
}
}
catch (SQLException sqlExcept)
{

}

}
}

此代码工作正常,但是当我尝试使用 ij 再次创建到同一数据库的连接时,我在命令提示符中收到如下错误:

enter image description here

在图片中,上半部分是我第一次创建数据库的时候,但是之后当我在 eclipse 中使用它时,它给了我这个错误。即使在 eclipse 中使用一次数据库也会导致此错误。

问题是什么?为什么 Derby 引擎没有获得授予它的访问权限?

感谢任何帮助。

最佳答案

我怀疑您混淆了这里的数据库模式。在您的问题标题中,您提到了“嵌入式 Derby”,但您的代码正在使用 ClientDriver 和 create=true 属性,如果数据库不存在,它会创建数据库,但它不存在t 启动服务器。

如果你不想启动服务器,你可以只使用EmbeddedDriver。

您可能会遇到问题的另一点是 shutdown=true 属性。您正在使用包括文件名的整个数据库 URL (dbURL),但是如果您想从您的代码中关闭服务器,您应该省略文件名,如下所示:jdbc:derby:;shutdown=true

您可以查看 Derby developer docs有关使用这些属性的信息,以及 Embedded Derby tutorial对于在嵌入式模式下使用 Derby,您不必担心启动服务器。

关于java - 访问被拒绝,嵌入式 Derby 中的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52051544/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com