Avatar billede mik28 Seniormester
13. oktober 2001 - 17:48 Der er 1 kommentar og
1 løsning

Resin, servlets og JDBC til MySQL

Er der en som kan fortælle mig hvordan jeg opretter en JDBC link i en Servlet.  Jeg har en klasse som hedder Databaseforbindelse. Mit gæt er. Det er det med driveren jeg er voldsomt i tvivl om, hvad hedder den og hvor på min maskine skal den ligge????

Databaseforbindelse d = new Databaseforbindelse(\"jdbc:mysql://min URL/databasens navn?user=bruger&password=password\", \"org.gjt.mm.mysql.Driver\");


                                                     
Avatar billede stig69 Nybegynder
14. oktober 2001 - 16:31 #1
Du skal benytte en driver:  mm.mysql-2.0.1-bin.jar kan hentes fra: http://mmmysql.sourceforge.net/
Læg den i biblioteket ...\\bin\\jdk1.3\\jre\\lib\\ext

Du skal ikke tilføje i Classpath med denne driver.

Dernæst benytter du dbHandler:

import java.io.*;
import java.sql.*;

public class DatabaseHandler extends Object {
   
    private Connection con=null;

    /** Creates new DataBase */
    public DatabaseHandler() {
    }

    public boolean open(String dbDriverName, String dbClassName, String user, String pass){           
        try{
            if(con==null){
                Class.forName(dbDriverName).newInstance();
                con = DriverManager.getConnection(dbClassName, user, pass);
            }
        }
        catch (SQLException e) {
            e.printStackTrace(System.out);
            return false;
        }
        catch (ClassNotFoundException e) {
            e.printStackTrace(System.out);
            return false;
        }
        catch (InstantiationException e) {
            e.printStackTrace(System.out);
            return false;
        }
        catch (IllegalAccessException e) {
            e.printStackTrace(System.out);
            return false;
        }
        return true;
    }
   
    public void close() {
        if(con!=null) {
            try {
                con.close();
                con=null;
            }
            catch (SQLException e) {
                e.printStackTrace(System.out);
            }
        }
    }
   
    public int doUpdate(String sql) {
        if(con!=null) {
            try {
                long time=System.currentTimeMillis();
                Statement stat=con.createStatement();
                System.out.println(\"SQL Update = \"+(System.currentTimeMillis()-time)+\" ms  \"+sql);
                return stat.executeUpdate(sql);       
            }
            catch (SQLException e) {
                e.printStackTrace(System.out);
            }
        }
        return 0;
    }

    public ResultSet doQuery(String sql) {
        if(con!=null) {
            try {
                long time=System.currentTimeMillis();
                Statement stat=con.createStatement();
                System.out.println(\"SQL Update = \"+(System.currentTimeMillis()-time)+\" ms  \"+sql);
                return stat.executeQuery(sql);       
            }
            catch (SQLException e) {
                e.printStackTrace(System.out);
            }
        }
        return null;
    }
}

Kalder den med:

DatabaseHandler db = new DatabaseHandler();

db.open(\"org.gjt.mm.mysql.Driver\",\"jdbc:mysql://HOSTNAME/DIN_DATABASE\",\"BRUGERNAVN\",\"PASSWORD\");

       

Det skulle være det. Held og lykke   
Avatar billede mik28 Seniormester
14. oktober 2001 - 16:40 #2
Tak skal du have. Jeg prøver, ellers vender jeg tilbage *G*.
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