我的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创建与同一数据库的连接时,在命令提示符下出现如下错误:
在图像中,上部是我第一次创建数据库时,但是此后当我在eclipse中使用它时,它给了我这个错误。即使在eclipse中使用一次db也会导致此错误。
出了什么问题?为什么derby引擎没有获得授予它的访问权限?
感谢您的帮助。
答案 0 :(得分:1)
我怀疑您在这里混淆了数据库模式。在问题标题中,您提到“嵌入式Derby”,但是您使用的代码是使用ClientDriver和 create = true 属性,如果属性不存在,该属性会创建数据库,但是它不会创建数据库。 t启动服务器。
如果您不想启动服务器,则可以使用EmbeddedDriver。
您可能会遇到问题的另一点是使用 shutdown = true 属性。您正在使用包括文件名在内的整个数据库URL(dbURL),但如果要从代码中关闭服务器,则应省略文件名,例如: jdbc:derby:; shutdown = true 。
您可以查看Derby developer docs来获得有关使用这些属性的信息,以及Embedded Derby tutorial来用于在嵌入式模式下使用Derby,因此您不必担心启动服务器。
答案 1 :(得分:0)
找出问题所在。我必须使用以下命令将derby作为端口上的网络服务器启动:
startNetworkServer.bat