querying embedded database in netbeans using derby

后端 未结 2 534
难免孤独
难免孤独 2020-11-30 14:39

I have created an embedded database using netbeans and added data to it. so now i want to query the database, the code runs smoothly but doesn\'t display data. Here is my co

相关标签:
2条回答
  • 2020-11-30 15:00

    You told us I have created an embedded database ... and added data to it.

    Thus, this database must be visible in Netbeans Services.

    enter image description here

    NO ;create=true !
    You should connect with the same URL you see in the properties. Nothing more.
    Expand Database URL or look at the bottom.

    enter image description here

     con = DriverManager.getConnection("jdbc:derby:C:/Dokumente und Einstellungen/Administrator/.netbeans-derby/sample","app","app");
    

    In the embedded mode Derby runs within the JVM (Java Virtual Machine) of the application. In this mode only the application can access the database, e.g. another user / application will not be able to access the database.

    Only one Application can acces the Database.
    So disconnect in Netbeans Services, the Database you want to connect to in your Application.

    0 讨论(0)
  • 2020-11-30 15:20

    I Would like to add an important clarification to the previous answer, because I found myself a bit lost during hours trying to make this thing functional. My point is for you to understand how Netbeans services tab works with embedded derby databases. When using:

     con = DriverManager.getConnection("jdbc:derby:CustDB;create=true", "app", "app");
    

    It creates the database in the same directory as your netbeans project. You can change this behavior by adding a directory path:

    jdbc:derby:directory_path/CustDB;create=true 
    

    So when you execute your program it will create the database in the specified path.

    Now, when you are creating a connection to an embedded database in the service tab, you are connecting to an existing database or creating a new one. I'm going to use Green's example:

    Once you execute for the first time the code from the first post with

    jdbc:derby:CustDB;create=true
    

    You create a database in the project's directory path. To be able to use an edit this database from the service tab, you must create a new connection to an embedded database. You must use the name CustDB, same user app and same password app.

    The very important thing here is to use the directory path of the project in the URL, so in the window when creating the connection in the URL field you must use:

    jdbc:derby:directory_path_of_the_project/CustDB;
    

    Now if yo press test connection button, everything should be alright.

    If you use here create=true without using the directory path of the project, you will create another database with the same name, same user and password but in a different location. Later you will find yourself making changes to the database in your code and not seeing them in the database in the service tab.

    0 讨论(0)
提交回复
热议问题