MySQL JDBC Result abfangen

Mole23

Aktives Mitglied
Hi zusammen,

ich versuche versuche gerade via JDBC auf eine MySQL-Datenbank zuzugreifen, allerdings bin ich mir nicht ganz sicher wie ich jetzt die Daten speichern kann. Die Verbindung scheint schonmal zu laufen.

Also über php würde ich ja wie folgt eine Abfrage starten:

$ergebnis_1 = mysql_query("select * from abteilung");

Kann mir einer sagen wie das mit der JDBC-Lib funktioniert?

Hier ist mein Code, allerdings verbinde ich mich da nur mit der Datenbank:


Code:
package sql;

import java.sql.*;

public class JDBCExample 
{
   // JDBC driver name and database URL
   static final String JDBC_DRIVER = "com.mysql.jdbc.Driver";  
   static final String DB_URL = "jdbc:mysql://localhost/Firma";

   static final String USER = "root";
   static final String PASS = "";
   
   public static void main(String[] args) 
   {
	   Connection conn = null;
	   
	   try
	   {
		   //JDBC driver registration
		   Class.forName("com.mysql.jdbc.Driver");

		   //Connection opening
		   System.out.println("Connecting to a selected database...");
		   conn = DriverManager.getConnection(DB_URL, USER, PASS);
		   System.out.println("Connected database successfully...");
	   }
	   
	   catch(SQLException se)
	   {
		   //Handle errors for JDBC
		   se.printStackTrace();
	   }
	   
	   catch(Exception e)
	   {
		   //Handle errors for Class.forName
		   e.printStackTrace();
	   }
	   
	   finally
	   {
		   //finally block used to close resources
		   try
		   {
			   if (conn != null)
			   {
				   conn.close();
			   }
		   }
		   
		   catch (SQLException se)
		   {
			   se.printStackTrace();
		   }
	   	}
	   
	   	System.out.println("Goodbye!");
	   	
   }
}


Vielen Dank schonmal vorweg... BEsten Gruß, Ole!
 

XHelp

Top Contributor
Hast du schon nach irgendeinem Beispiel gesucht? "java mysql example" liefert dir mit sicherheit 1,2...1000 Ergebnisse
 

Mole23

Aktives Mitglied
Hi zusammen,

erstmal danke für die recht freundlichen Antworten^^ Also auf die Idee ein Tutorial zur hilfe zu nehmen, bin ich dann auch schon gekommen. Ich würde mir auch bestimmt nicht um halb eins Nachts die Mühe machen, hier noch ein Post zu schreiben, wenn ich das selber hinbekommen würde. Sorry, bin nicht so die Programierleuchte...

Laut den Tutorials, soll ich ein Statement erzeugen und dieses dann in ein ResultSet speichern.

Wenn die Variablen erstellt sind in etwa so: resultSet = statement

Im Anschluss kann ich ja dem Ganzen meine Abfrage hinzufügen, wenn man das so sagen kann:

.executeQuery("select * from abteilung");
writeResultSet(resultSet);


Lasse ich mir aber dieses resultSet anzeigen, erhalte ich nur "null"...

Da ich mir aber nicht sicher war, ob der Weg über dieses ResultSet überhaupt der Richtige ist, wollte ich erstmal erfragen wie das im allgemeinen geht...

Gruß, Ole!
 

ARadauer

Top Contributor
soll ich ein Statement erzeugen und dieses dann in ein ResultSet speichern.
wer sagt das? Das Statement bietet dir eine Methode um eine Quey abzusetzen, welches ein ResultSet zurück liefert

Wenn die Variablen erstellt sind in etwa so: resultSet = statement
wo hast du das gesehen?

Im Anschluss kann ich ja dem Ganzen meine Abfrage hinzufügen, wenn man das so sagen kann:

.executeQuery("select * from abteilung");
writeResultSet(resultSet);
nö!
statement von connection erzeugen,
query mit statement ausführen was ein ResultSet zurück liefert..

Lasse ich mir aber dieses resultSet anzeigen, erhalte ich nur "null"...
wie machst du das? es gibt kein writeResultSet?

wollte ich erstmal erfragen wie das im allgemeinen geht...
wie es in jedem tutorial gezeigt wird... das was du da beschreibst, hast du dir selber zusammen geträumt... bzw da hätte ich gerne die quelle

ok so schauts ungefähr aus


Java:
         Connection connection = DriverManager.getConnection(DB_URL, USER, PASS); //zb aber das hast du ja schon
         Statement stmt = connection.createStatement(); //Statment erzeugen
         ResultSet rs =stmt.executeQuery("select name, vorname from user"); //Abfrage absetzen
         while(rs.next()) //über die Zeilen gehen
            System.out.println(rs.getString("name") + rs.getString("vorname")); // Werte auslesen
         }


ungfähr ... ohne sauberes exception handling und schließen der resourcen...
 

ARadauer

Top Contributor
ok jetzt will ichs nochmal genau wissen...

jdbc tutorial - Google-Suche

1. Trail: JDBC(TM) Database Access (The Java™ Tutorials)
Java:
Connection con = DriverManager.getConnection
           ( "jdbc:myDriver:wombat", "myLogin","myPassword");
			  
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery("SELECT a, b, c FROM Table1");
while (rs.next()) {
	int x = rs.getInt("a");
	String s = rs.getString("b");
	float f = rs.getFloat("c");
	}
eigentlich genau der code von mir...

2. Java JDBC Tutorial
ok die seite erzählt ein bisschen viel... aber bei retrieving records ... ganz unten

Java:
try {
			stmt = con.createStatement();
			ResultSet rs = stmt.executeQuery(selectString);
			while (rs.next()) {
				int pr_id = rs.getInt(”Prod_ID”);
				String prodName = rs.getString(”ProductName”);
			    int id = rs.getInt(”Employee_ID”);
			    result +=pr_id+”\t\t”+ prodName+”\t\t”+id+”\n”;
			}
			stmt.close();
			con.close();

		} catch(SQLException ex) {
			System.err.println(”SQLException: ” + ex.getMessage());
		}
createStatement, executeQuery, rs.next... kommt uns bekannt vor...

3. JDBC - Quick Guide

Java:
//STEP 2: Register JDBC driver
      Class.forName("com.mysql.jdbc.Driver");

      //STEP 3: Open a connection
      System.out.println("Connecting to database...");
      conn = DriverManager.getConnection(DB_URL,USER,PASS);

      //STEP 4: Execute a query
      System.out.println("Creating statement...");
      stmt = conn.createStatement();
      String sql;
      sql = "SELECT id, first, last, age FROM Employees";
      ResultSet rs = stmt.executeQuery(sql);

      //STEP 5: Extract data from result set
      while(rs.next()){
         //Retrieve by column name
         int id  = rs.getInt("id");
         int age = rs.getInt("age");
         String first = rs.getString("first");
         String last = rs.getString("last");

         //Display values
         System.out.print("ID: " + id);
         System.out.print(", Age: " + age);
         System.out.print(", First: " + first);
         System.out.println(", Last: " + last);
      }
      //STEP 6: Clean-up environment
      rs.close();

mhn passt.... immer das gleiche...

Also auf die Idee ein Tutorial zur hilfe zu nehmen, bin ich dann auch schon gekommen.
klar... wir helfen gerne, aber ein bisschen muss man sich schon selber helfen können...
 

Mole23

Aktives Mitglied
Hi, erstmal danke für die Mühe. Also, ich habe folgendes Tutorial benutzt, da ich das auf der JDBC Seite vergebens gesucht hatte. Kp warum, aber ich bin immer nur auf das Tutorial gestoßen, dass nach dem connect endet.

MySQL and Java JDBC - Tutorial

Ich habe das gerade noch einmal durchgelesen und es funktioniert jetzt auch, also danke. Aber mal im Ernst, das wäre von deiner Seite her mit drei Sätzen erledigt gewesen. Naja seis drum...

Besten Gruß, Ole!
 
J

JohannisderKaeufer

Gast
Wobei lars Vogel auch folgendes drin hat.
Java:
statement = connect.createStatement();
			// Result set get the result of the SQL query
			resultSet = statement
					.executeQuery("select * from FEEDBACK.COMMENTS");
			writeResultSet(resultSet);

...

private void writeResultSet(ResultSet resultSet) throws SQLException {
		// ResultSet is initially before the first data set
		while (resultSet.next()) {
			// It is possible to get the columns via name
			// also possible to get the columns via the column number
			// which starts at 1
			// e.g. resultSet.getSTring(2);
			String user = resultSet.getString("myuser");
			String website = resultSet.getString("webpage");
			String summery = resultSet.getString("summery");
			Date date = resultSet.getDate("datum");
			String comment = resultSet.getString("comments");
			System.out.println("User: " + user);
			System.out.println("Website: " + website);
			System.out.println("Summery: " + summery);
			System.out.println("Date: " + date);
			System.out.println("Comment: " + comment);
		}
	}

was wenn man die Methode Inlined etwa so aussieht.
Java:
statement = connect.createStatement();
			// Result set get the result of the SQL query
			resultSet = statement.executeQuery("select * from FEEDBACK.COMMENTS");
	while (resultSet.next()) {
			// It is possible to get the columns via name
			// also possible to get the columns via the column number
			// which starts at 1
			// e.g. resultSet.getSTring(2);
			String user = resultSet.getString("myuser");
			String website = resultSet.getString("webpage");
			String summery = resultSet.getString("summery");
			Date date = resultSet.getDate("datum");
			String comment = resultSet.getString("comments");
			System.out.println("User: " + user);
			System.out.println("Website: " + website);
			System.out.println("Summery: " + summery);
			System.out.println("Date: " + date);
			System.out.println("Comment: " + comment);
		}

was wiederum das selbe ist ist wie bei ARadauer
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
H com.mysql.jdbc.NotUpdatable: Result Set not updatable Datenbankprogrammierung 2
B SQLite + jdbc + IntelliJ-Consumer = "No suitable driver found..." Datenbankprogrammierung 15
J PC-Start Problem JDBC Connection Datenbankprogrammierung 10
N JDBC SQLITE und Cascading Datenbankprogrammierung 2
D Asynchrone Aufrufe mit jdbc Datenbankprogrammierung 5
Edin JDBC Hilfe Datenbankprogrammierung 2
H JDBC Tabellen ausgeben Datenbankprogrammierung 8
Husamoli345 JSF-JDBC Verbindung Crud Datenbankprogrammierung 15
G MySQL JDBC Metadaten auslesen aus .accdb -> Primärschlüssel manchmal erkannt manchmal nicht Datenbankprogrammierung 3
N Java, sql, jar, JDBC-Treiber in Classpath Datenbankprogrammierung 8
O Create Table per JDBC Fehler: ORA-00922 Datenbankprogrammierung 4
J JDBC anschaulich präsentieren Datenbankprogrammierung 2
Thallius MySQL JDBC auf Linux Server zu mySQL DB auf anderem Linux Server wirft Access denied Datenbankprogrammierung 5
ralfb1105 Oracle JDBC Debugging Datenbankprogrammierung 8
Z [JDBC][MYSQL] Access denied Datenbankprogrammierung 7
Thallius MySQL jdbc schließt Verbindung nach vielen Request von selber Datenbankprogrammierung 8
B MySQL JDBC Kommentarfilter Datenbankprogrammierung 4
Aruetiise MySQL Name JDBC Drive finden Datenbankprogrammierung 4
E Sqlite-jdbc Mitliefern Datenbankprogrammierung 4
R jdbc-Zugriff Nicht erlaubt ? Datenbankprogrammierung 16
S probleme mit dem jdbc treiber Datenbankprogrammierung 1
Thallius MySQL Merkwürdiges JDBC Verhalten bei VPN Verbindung. Datenbankprogrammierung 7
O JDBC Daten in zwei Tabellen mit zwei foreach-Schleifen einfügen (insert into) Datenbankprogrammierung 1
F MySQL JDBC Problem Datenbankprogrammierung 5
C JDBC und SQLite Datenbank Datenbankprogrammierung 8
looparda SQLite Active JDBC Abstraktion Datenbankprogrammierung 2
J JDBC SQL Statement mit Parameter Datenbankprogrammierung 7
S JDBC PreparedStatement durchiterieren Datenbankprogrammierung 6
J RESTServie + JDBC + No suitable driver found for jdbc Datenbankprogrammierung 4
KaffeeFan JDBC/ODBC-Bridge entfernt Datenbankprogrammierung 4
S sun.jdbc.odbc.JdbcOdbcDriver wird nicht gefunden Datenbankprogrammierung 2
J Fehlende DatenbankView nach einbeziehen von JDBC Datenbankprogrammierung 3
A Mit JDBC auf postgreSQL Datenbank zugreifen Datenbankprogrammierung 5
C PostgreSQL JDBC + PostgreSQL: getLong liefert 0 statt NULL Datenbankprogrammierung 2
flenst111 SQL-Statement Wie konfiguriert man JDBC-Connect.richtig, damit es bei riesigen Tabs keinen Speicherüberlauf gibt? Datenbankprogrammierung 1
M JDBC Tabellen mit Boolean Spalten können nicht erstellt werden. DB Updaten - wie? Datenbankprogrammierung 6
S JDBC mit Postgres DB connecten Datenbankprogrammierung 3
A Eine MySQL Zeile mit JDBC löschen Datenbankprogrammierung 5
D JDBC - Verständnisfrage Datenbankprogrammierung 2
C Tabelle erstellen mit Apache JDBC-Util Datenbankprogrammierung 1
L Conversion-Error bei JDBC Date Literals Datenbankprogrammierung 3
X MySQL DB-verbindung ohne JDBC/ODBC Datenbankprogrammierung 1
F sun.jdbc.odbc.jdbcodbcdriver wird nicht gefuden Datenbankprogrammierung 3
J Keine Verbindung zu MSSQL DB mit JDBC Datenbankprogrammierung 3
U JDBC prepaird Statements Datenbankprogrammierung 4
B MySQL JDBC Zugriff auf entfernt Datenbank, fehlende Rechte Datenbankprogrammierung 2
Q MySQL JDBC-Treiber Problem Datenbankprogrammierung 2
R Transaktionen von mehreren Anwendungen aus - JDBC Datenbankprogrammierung 3
N MySQL com.microsoft.sqlserver.jdbc.SQLServerException: Die Verbindung wurde geschlossen. Datenbankprogrammierung 1
N JDBC: rollback() bei Exception geht nicht!? Datenbankprogrammierung 1
C Dateipfad des jdbc Treibers Datenbankprogrammierung 2
G JDBC Connect nur über SID fehlerfrei möglich Datenbankprogrammierung 2
R Oracle jdbc Zugriff auf Oracle Datenbankprogrammierung 2
T JDBC Fehler Datenbankprogrammierung 2
J JDBC via Singleton Datenbankprogrammierung 12
Z PostgreSQL JDBC mit Postgresql Datenbankprogrammierung 2
B No suitable driver found for jdbc:oracle:thin:@$HOST:$PORT:$SID Datenbankprogrammierung 7
K JDBC via Netzwerk Datenbankprogrammierung 4
B JDBC Connection Fehler Datenbankprogrammierung 8
K JDBC- In Java "stored procedure" erstellen für DB2,OracleSql ... Datenbankprogrammierung 3
J JDBC in Library|"Treiber konnte nicht geladen werden"" Datenbankprogrammierung 2
B JDBC-Connection: Data source name too long Datenbankprogrammierung 3
D JDBC insert mit select abfrage Datenbankprogrammierung 5
A JDBC Prepared Statement Autoincrement Datenbankprogrammierung 3
H JDBC prüfen ob Table existiert Datenbankprogrammierung 3
crashfinger jdbc-connection mit jre7 funktioniert nicht Datenbankprogrammierung 5
0 JDBC Oracle Verbindungsaufbau Datenbankprogrammierung 6
Q Oracle Linux: ClassNotFoundException: oracle.jdbc.driver.OracleDriver Datenbankprogrammierung 6
B JDBC MySQL Statement Datenbankprogrammierung 3
F Oracle Oracle JDBC Anbindung unter Glassfish 3.1.2 Datenbankprogrammierung 3
V PostgreSQL JDBC Treiber fehlt Datenbankprogrammierung 6
Y JDBC - Datenbankabfrage Webserver Datenbankprogrammierung 4
C JDBC Datenbank funktioniert nicht Datenbankprogrammierung 7
C JDBC , JDO oder JPA Datenbankprogrammierung 17
J MySQL Datenbank konfigurieren, JDBC, MySQL oder Hibernate Datenbankprogrammierung 2
P JDBC Verbindung zur DB klappt nicht Datenbankprogrammierung 6
J Java - JDBC Verbindung zur Datenbank nicht möglich Datenbankprogrammierung 10
K JDBC Buch kaufen? Datenbankprogrammierung 3
K Hibernate vs. JDBC Datenbankprogrammierung 4
K JDBC Driver not found Datenbankprogrammierung 10
GianaSisters Per JDBC auf Microsoft SQL 2005 Datenbankprogrammierung 24
S ich brauche tipps für JDBC Datenbankprogrammierung 4
Paristick MSSQL - JDBC Exception beim Registrieren Datenbankprogrammierung 5
S Applet stucks at SQL Connection (jTDS JDBC) Datenbankprogrammierung 15
R MySQL Voraussetzungen für eine erfolgreiche Datenbankanbindung mittels JDBC Datenbankprogrammierung 2
c_sidi90 JDBC Oracle Connection schlägt fehl Datenbankprogrammierung 2
J jdbc-dataSource in Klassen nutzen Datenbankprogrammierung 2
H Rechnen in Datenbanken - JDBC Mittel der Wahl? Datenbankprogrammierung 32
K MySQL JDBC - Access Datenbank - unbekannter TabellenName Datenbankprogrammierung 4
D JDBC Fehler beim laden der nativen Bibliothek db2jcct2 Datenbankprogrammierung 9
J MySQL Verbindung über JDBC scheitert immer Datenbankprogrammierung 2
I Master/Detail Tabellen mit JDBC und Swing Datenbankprogrammierung 10
S MSSQL JDBC "Driver class not found" Datenbankprogrammierung 9
E Datenbankverbindung mit Oracle JDBC und Eclipse Plugin Quantum db Datenbankprogrammierung 2
ruutaiokwu jdbc connection als singleton Datenbankprogrammierung 11
J MySQL Löschen von Rows mit JDBC Datenbankprogrammierung 9
G JDBC Exception Datenbankprogrammierung 3
Screen Ich suche eine SQLDatenbank ohne JDBC-Treiber Datenbankprogrammierung 12
F Fehlerhandling bei JDBC Datenbankprogrammierung 9
T JDBC und Arrays Datenbankprogrammierung 7

Ähnliche Java Themen

Neue Themen


Oben