Avatar billede bagnavnet Nybegynder
11. december 2004 - 14:23 Der er 9 kommentarer og
1 løsning

Hent værdier fra DB

Hej,

Jeg forsøger med denne kode at hente nogle værdier op fra min DB:
------------------
    public Vector hentVarer() throws SQLException
            {
              Vector alle = new Vector();
              ResultSet rs = stmt.executeQuery("select VARE_ID, NAVN, PRIS from VARE");
              while (rs.next())
              {
                // brug kolonneindeks i stedet for kolonnenavn
                Vare v = new Vare( rs.getString(1), rs.getString(2), rs.getDouble(3));
                alle.addElement(v);
                }
                System.out.println("vare:  " +1+ ": " +2+ ":  " +3);
              return alle;
             
            }
----------------
det har jeg ikke held med, mangler jeg noget?
Avatar billede mikkelbm Nybegynder
11. december 2004 - 14:27 #1
Hvad får du af fejl?
Avatar billede mikkelbm Nybegynder
11. december 2004 - 14:28 #2
Og så kan jeg heller ikke forestille mig, at dit vare_id er en string !?

rs.getString(1)

skal måske være

rs.getInt(1)

?
Avatar billede bagnavnet Nybegynder
11. december 2004 - 14:33 #3
JEg får denne fejl:
--------
java.lang.NullPointerException
    at DatabaseManager.hentVarer(DatabaseManager.java:41)
    at OracleTest.main(OracleTest.java:11)
Avatar billede mikkelbm Nybegynder
11. december 2004 - 14:36 #4
Det er ikke fordi dit Statement smtp er null - ligesom i sidste spørgsmål :)?

conn.createStatement().executeQuery(.....);

Eller

Statement stmt = conn.createStatement();
stmt.executeQuery(....);
Avatar billede mikkelbm Nybegynder
11. december 2004 - 14:36 #5
"Det er ikke fordi dit Statement smtp..."

smtp = stmt

:)
Avatar billede bagnavnet Nybegynder
11. december 2004 - 14:58 #6
jooo, det var nok det, hehe. Men, problemerne vil ingen ende tage, så nu får jeg følgende:
-----------------
public Vector hentVarer() throws SQLException
            {
              Vector alle = new Vector();
              ResultSet rs = conn.createStatement().executeQuery("select VARE_ID, NAVN, PRIS from VARE");
              while (rs.next())
              {
                // brug kolonneindeks i stedet for kolonnenavn
                Vare v = new Vare( rs.getInt(1), rs.getString(2), rs.getInt(3));
                alle.addElement(v);
                }
                System.out.println("vare:  " +rs.getInt(1)+ ": " +rs.getString(2)+ ":  " +rs.getInt(3));
              return alle;
             
            }
-----------------------
FEJL:
---------------------
java.sql.SQLException: Opbrugt resultatsæt
    at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:180)
    at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:222)
    at oracle.jdbc.dbaccess.DBError.throwSqlException(DBError.java:285)
    at oracle.jdbc.driver.OracleStatement.prepare_for_new_get(OracleStatement.java:2791)
    at oracle.jdbc.driver.OracleStatement.getIntValue(OracleStatement.java:3754)
    at oracle.jdbc.driver.OracleResultSetImpl.getInt(OracleResultSetImpl.java:332)
    at DatabaseManager.hentVarer(DatabaseManager.java:48)
    at OracleTest.main(OracleTest.java:11)
Avatar billede mikkelbm Nybegynder
11. december 2004 - 15:21 #7
Det er fordi du i denne linje:

System.out.println("vare:  " +rs.getInt(1)+ ": " +rs.getString(2)+ ":  " +rs.getInt(3));

prøver at hente værdier ud af dit ResultSet når der ikke er flere!

Den linje udskriver du jo, når while løkken er færdigkørt - altså når der ikke er flere værdier.
Avatar billede mikkelbm Nybegynder
13. december 2004 - 15:21 #8
Jeg smider et svar i tilfæle af at det var brugbart.
Avatar billede mikkelbm Nybegynder
20. december 2004 - 00:20 #9
Husk at lukke spørgsmålet :)
Avatar billede mikkelbm Nybegynder
22. januar 2005 - 18:07 #10
Fandt du en løsning?
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester