South_Bridge Skrevet 2. mai 2007 Del Skrevet 2. mai 2007 Har installert og fått MySQL til å fungere - yay! Jeg har også laget en database. I databasen har jeg laget en enkel tabel med følgende verdier: bil båt hus sykkel Verdiene er lagt til med javaprogrammet mitt. Men jeg er glemst, og ønsker å søke igjennom lista mi med en knapp i javaprogrammet mitt. Så når jeg trykker på den kommer det opp en JOptionPane og spør hva jeg vil søke etter. JOptionPane er en string. Spørsmålet mitt er da hvordan jeg får søkt og vist resultatet av søket i JTextArea jta (feks). Jeg får kobla til rett database og slikt, men jeg har lett en stund etter søke funksjon som gir output. i mysql command line vinduet er kommandoen select * from liste where stuff like '%hus%'; men somsagt vet jeg ikke hvordan jeg kan hente verdier til javaprogrammet mitt. Lenke til kommentar
pgdx Skrevet 3. mai 2007 Del Skrevet 3. mai 2007 Hvilke metode bruker du for å kjøre query/hente data, og hva er returtypen dens? Lenke til kommentar
bjornoss Skrevet 3. mai 2007 Del Skrevet 3. mai 2007 (endret) Noe sånn som dette kanskje: public List<String> search(String searchString) { List<String> res = new ArrayList<String>(); String sql = "select * from liste where stuff like '%" + searchString + "%'"; Connection con = null; Statement st = null; ResultSet rs = null; try { con = getConnection(); st = con.createStatement(); rs = st.executeQuery(sql); while (rs.next()) { res.add(rs.getString(1)); } } catch (SQLException e) { System.err.println(e); } finally { releaseConnection(con); } return res; } getConnection() og releaseConnection() er metoder som åpner og lukker db koblinger. Siden du har lagret verider der så regner jeg med ut vet hvordan du gjør dette. Det som er viktig her er: rs.getString(1), denne metoden henter ut en String i første kolonne i resultatet av spørringen: select * from liste where stuff like '%" + searchString + "%'. Det finnes også rs.getInt(int kolonne) osv. Nå er det bare å legge resultatet i JTextArea eller hvor du vil. -bjornoss Edit: rettet en feil i koden. Endret 3. mai 2007 av bjornoss Lenke til kommentar
krigun Skrevet 3. mai 2007 Del Skrevet 3. mai 2007 MySQL støtter også fulltext søk indekser, noe bedre enn LIKE: http://dev.mysql.com/doc/refman/5.0/en/fulltext-search.html Lenke til kommentar
Anbefalte innlegg
Opprett en konto eller logg inn for å kommentere
Du må være et medlem for å kunne skrive en kommentar
Opprett konto
Det er enkelt å melde seg inn for å starte en ny konto!
Start en kontoLogg inn
Har du allerede en konto? Logg inn her.
Logg inn nå