Avatar billede jsl Nybegynder
30. april 2005 - 21:24 Der er 8 kommentarer og
1 løsning

Tæl antal poster i SQL db

Jeg laver en databaseapplikation i jBuilder, hvor jeg vil lave div. statistik. Hvordan tæller jeg antallet af poster i SQL databasen, der opfylder bestemte kriterier?
Avatar billede magoo20000 Nybegynder
30. april 2005 - 21:26 #1
Tænker du ikke bare på select count(*) from x where ..... ?
Avatar billede magoo20000 Nybegynder
30. april 2005 - 21:27 #2
F.eks.
ResultSet r = stmt.executeQuery("SELECT COUNT(*) FROM X Where age < 25");
r.next();
int count = r.getInt(1);
r.close() ;
Avatar billede jsl Nybegynder
30. april 2005 - 21:53 #3
For at det virker, skal jeg så ikke huske at skrive det her:
        Statement stmt = con.createStatement(
                                ResultSet.TYPE_SCROLL_INSENSITIVE,
                                ResultSet.CONCUR_UPDATABLE);
Avatar billede jsl Nybegynder
30. april 2005 - 22:00 #4
Jeg har problemer med, at den ikke vil genkende con.
Avatar billede jsl Nybegynder
30. april 2005 - 22:15 #5
Problemerne er løst. Der var lidt bøvl med nogle variabeler. :-)
Avatar billede magoo20000 Nybegynder
30. april 2005 - 22:30 #6
Okay. Det er i øvrigt ikke alle DBMS, der understørret dine to statiske variabler på ResultSet. Virker det hele nu?
Avatar billede jsl Nybegynder
30. april 2005 - 23:04 #7
Ja, det virker. Jeg har nu lavet flg. Kan det gøres smartere?

Statement stmt = con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE,ResultSet.CONCUR_UPDATABLE);
ResultSet total = stmt.executeQuery("SELECT COUNT(*) FROM TBL_SAM_ELEV;");
total.next();
int totalCount = total.getInt(1);
total.close();
lblTotal.setText("Total:  " +totalCount);
         
ResultSet undervisning = stmt.executeQuery("SELECT COUNT(*) FROM TBL_SAM_ELEV WHERE STATUS = 'Undervisning';");
undervisning.next();
int undervisningCount = undervisning.getInt(1);
undervisning.close();
lblUndervisning.setText("Undervisning:  " +undervisningCount);
Avatar billede magoo20000 Nybegynder
03. maj 2005 - 20:57 #8
Det ser fint ud. Evt. kunne man blot lave et resultset (f.eks. ResultSet resultSet = ...), og så genbruge det begge steder og så lukke det til sidst.
Avatar billede jsl Nybegynder
03. maj 2005 - 21:12 #9
Tak. Så er der lukketid....
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