Variable Werte in einem SQL Statement?

Status
Nicht offen für weitere Antworten.

Java Light

Aktives Mitglied
Hallo

Ist es möglich mit einem SQL statement eine Variable zu übergeben? Etwa so:

Code:
Room room1 = new Room;
description = room1.getDescription();
executeUpdate(1, 150, 'Doppelzimmer', 0, description)

Leider funktioniert diese Variante bei mir nicht, welche Möglichkeiten gibt es da?


Danke für Eure Unterstützung...
 

AlArenal

Top Contributor
Ich würds statt mit Code-Vandalismus mal mit RTFM probieren.. Du kannst dir doch nicht irgendwelche Befehle ausdenken und dich dann wundern, dass sie nicht funktionieren..

Im Netz, im Forum, in unseren FAQs dürftest du totgeschmissenw erden mit JDBC-Tutorials und Codefetzen.
 

Java Light

Aktives Mitglied
Entschuldigung...ich habe nicht alles in meinem Statement geschrieben, habe ein Teil vergessen:

Natürlich lautet meine Codezeile folgendermassen:

Code:
Room room1 = new Room; 
description = room1.getDescription(); 
executeUpdate(insert into room values (1, 150, 'Doppelzimmer', 0, description);  // Korrektur

Tut mir schrecklich leid...leider beantwortet dies meine Frage noch nicht.[/code]
 

AlArenal

Top Contributor
Vielleicht solltest du mal nen Blick auf die Fehlermeldung werfen, die du beim Kompilieren bekommst.. Vielleicht geht dir dann ein Licht auf.
 

DP

Top Contributor
poste mal komplettencode. was funktioniert wo nicht?

im 2. code fehlt schonmal ne geschlossene klammer usw. pp
 

trmx

Mitglied
vielleicht so

Code:
executeUpdate("insert into room values (1, 150, 'Doppelzimmer', 0, '" + description + "')");

:meld: Für Parameter sind PreparedStatements besser!
 

Java Light

Aktives Mitglied
Hallo zusammen

Besten Dank für Eure Antworten, leider hat es nicht funktioniert. Hier nun mein gesamter Code:

Code:
package ch.essec.sherin;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;
import java.sql.SQLException;
import java.sql.Statement;

// javac HelloJDBC.java
// java -classpath /home/marnitz/ojdbc14.jar:/home/marnitz/ HelloJDBC
// jdbc:oracle:thin:@deanston.cs.uni-magdeburg.de:1521:tix

public class DatabaseRoom {
	
	private static String query = null; // Anfragestring
	private static Connection connection = null; //Verbindung zur Datenbank
	private String description;
	
	
	
	/**
	 * Oeffnen einer Datenbankverbindung
	 */
	public void initDBConnection(){
		String url ="jdbc:mysql://localhost/hotelreservationssystem"; //URL zur Datenbank
		String username = "root"; //Nutzername
		String password = ""; //Passwort
				
		// Holen des SQL-Treibers
		try {
			Class.forName("com.mysql.jdbc.Driver");
		}
		catch(ClassNotFoundException e1) {
			e1.printStackTrace();
			System.exit(1);
		}
		//Erstellung einer Verbindung zur Datenbank
		try {
			connection = DriverManager.getConnection(url, username, password);
			//Ausfuehren einer DB-Anfrage
			executeQuery();
			//Schliessen der DB-Verbindung
			connection.close();
		}catch (SQLException e) {
			e.printStackTrace();
		}
	}
	/**
	 * Ausfuehrung der DB-Anfrage
	 */
	public void executeQuery(){
		try {
			/**
			 * Hier wird die DB-Anfrage gesetzt!!!!
			 */
			Room room = new Room();
			description = room.getRoomDescription();
			query = "insert into room VALUES (8, 150, 'Doppelzimmer', 0, " + description + ")"; 
			//query = "select * from cocktail"; 
			//Erzeugung eines Statements
			Statement statement = connection.createStatement();
			//Holen Ergebnismenge der Anfrage
			statement.executeUpdate(query);
		} catch (SQLException e) {
			e.printStackTrace();
		}		
	}
}

Übrigens wird mir folgende Fehlermeldung ausgegeben:

com.mysql.jdbc.exceptions.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'Zimmer)' at line 1
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:936)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2870)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1573)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:1665)
at com.mysql.jdbc.Connection.execSQL(Connection.java:3118)
at com.mysql.jdbc.Statement.executeUpdate(Statement.java:1313)
at com.mysql.jdbc.Statement.executeUpdate(Statement.java:1232)
at ch.essec.sherin.DatabaseRoom.executeQuery(DatabaseRoom.java:66)
at ch.essec.sherin.DatabaseRoom.initDBConnection(DatabaseRoom.java:41)
at ch.essec.sherin.RoomErfassung.main(RoomErfassung.java:10)
com.mysql.jdbc.exceptions.MySQLNonTransientConnectionException: No operations allowed after connection closed.
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:888)
at com.mysql.jdbc.Connection.checkClosed(Connection.java:1903)
at com.mysql.jdbc.Connection.createStatement(Connection.java:2962)
at com.mysql.jdbc.Connection.createStatement(Connection.java:2944)
at ch.essec.sherin.DatabaseRoom.executeQuery(DatabaseRoom.java:64)
at ch.essec.sherin.RoomErfassung.main(RoomErfassung.java:11)

Auch wenn ich das Manual anschaue, finde ich keinen Fehler...was mache ich bloss falsch?

Falls mir jemand helfen könnte...Besten Dank...
 
S

SlaterB

Gast
dein erster Fehler ist schon mal dir weder die Tabelle in der Datenbank noch die Anfrage anzuschauen,

hinter jeder Query, die noch nicht sicher funktioniert gehört ein
System.out.println(query);

ich nehme mal an die Query lautet
"insert into room VALUES (8, 150, 'Doppelzimmer', 0, Zimmer)"

und in einem solchen Fall ist dein gesamtes Programm egal,
denn diese Query würde auch nicht funktionieren, wenn du sie direkt eintippen würdest, statt per Variable,

wie man Strings eingibt weißt du doch anscheinend:
da müssen einfache Anführungsstriche rum wie bei 'Doppelzimmer'
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
D Datei auslesen & Werte in Variable speichern Java Basics - Anfänger-Themen 12
V Warum speichert meine String-Variable nummerische Werte? Java Basics - Anfänger-Themen 3
C Erste Schritte Array Werte Ausgeben Probleme mit variable Java Basics - Anfänger-Themen 21
R Php werte in jquery variable speichern für autocomplete Java Basics - Anfänger-Themen 7
B Werte der Variable aus Klasse JTextArea in einer Datei der Klasse RandomAcessFile speichern Java Basics - Anfänger-Themen 10
S Werte aus Datei lesen und in Variable abspeichern Java Basics - Anfänger-Themen 4
M Länge eines Arrays als Variable speichern möglich? Java Basics - Anfänger-Themen 14
R Liste in Variable speichern Java Basics - Anfänger-Themen 6
J Java long- in int-Variable umwandeln Java Basics - Anfänger-Themen 6
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
E Variable von 1. Fenster an 2. Fenster übergeben. Java Basics - Anfänger-Themen 7
T Variable in Schleife deklarieren, Speicherplatz, Garbage Collector Java Basics - Anfänger-Themen 10
T Datum als Variable wert Java Basics - Anfänger-Themen 4
G Variable aktualisiert sich nicht in rekursiver Methode Java Basics - Anfänger-Themen 4
R Compiler-Fehler Variable wird nicht gefunden bzw. erkannt? Java Basics - Anfänger-Themen 2
Say super.methode / super.variable und super(variable) Java Basics - Anfänger-Themen 2
M variable in anderer funktion aufrufen Java Basics - Anfänger-Themen 10
N Was Passiert mit dem Namen einer Variable, wenn man diese einer Liste Hinzufügt Java Basics - Anfänger-Themen 16
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
U Wie mache ich die Variable xyz eindeutig/unique? Java Basics - Anfänger-Themen 20
JordenJost char variable funktioniert irgendwie nicht a+b ergibt nicht à Java Basics - Anfänger-Themen 4
M Variable Felderanzahl Java Java Basics - Anfänger-Themen 10
T Variable durch Action Listener ändern Java Basics - Anfänger-Themen 2
stormyark Fehler beim überschreiben einer Variable Java Basics - Anfänger-Themen 1
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
S Eine Variable in einem Array speichern Java Basics - Anfänger-Themen 5
I Methoden Wieso wird mein Array "a" verändert und meine Variable "a" nicht? Java Basics - Anfänger-Themen 4
M Variable in einer Schleife initialisieren Java Basics - Anfänger-Themen 46
W Schleife und einmal variable++ zu viel Java Basics - Anfänger-Themen 20
M String mit Variable vergleichen Java Basics - Anfänger-Themen 9
M Methoden Wert einer Variable geht verloren? Java Basics - Anfänger-Themen 6
G variable kopieren bzw. woanders benutzen Java Basics - Anfänger-Themen 6
Ameise04 Variablen Inhalt einer Variable im Code verwenden? Java Basics - Anfänger-Themen 9
J Double Variable und Addition Java Basics - Anfänger-Themen 2
I Variable innerhalb Methode: Local variable test defined in an enclosing scope must be final or effectively final Java Basics - Anfänger-Themen 3
KogoroMori21 Variable im Parameter und Ohne Java Basics - Anfänger-Themen 5
Vivien Auf eine Variable von einer anderen Klasse aus zugreifen Java Basics - Anfänger-Themen 3
H Datentypen Wertebereich von <Klassenname> <Variable> Java Basics - Anfänger-Themen 12
M Private Variable Java Basics - Anfänger-Themen 2
idontknow707 Matrix nach z.B. Variable durchsuchen Java Basics - Anfänger-Themen 4
T Variable in for Schleife ansprechen ohne Array ? Java Basics - Anfänger-Themen 25
s.marcii Modulo in der Variable einsetzen - ist das möglich? Java Basics - Anfänger-Themen 2
N Variable aus anderen Variablen in statischer Klasse berechnen/abspeichern? Java Basics - Anfänger-Themen 4
Y Wie kann ich die Variable in der Try Catch returnen? Java Basics - Anfänger-Themen 3
K Übergabe des Wertes einer Variable aus main() in eine Klassenmethode Java Basics - Anfänger-Themen 8
B Inkrement von Variable Java Basics - Anfänger-Themen 8
V Variablen statische Variable einer Objektvariable zuordnen Java Basics - Anfänger-Themen 3
L Variable von einer Methode zu einer anderen Methode inkl. einer "Zwischenmethode" Java Basics - Anfänger-Themen 1
J JTextField Bezeichnung als Variable Java Basics - Anfänger-Themen 3
N Wie kann ich eine meine Variable Final machen? Java Basics - Anfänger-Themen 1
NeoLexx Variable für Array wird nicht korrekt übergeben Java Basics - Anfänger-Themen 45
M Enum-Variable HashMap zuweisen Java Basics - Anfänger-Themen 5
H Variable um 1 erhört ausgeben Java Basics - Anfänger-Themen 4
V Erste Schritte Eine Array-Variable mit Benutzereingaben befüllen Java Basics - Anfänger-Themen 3
J Fehlermeldung unklar. non-static variable player0 cannot be referenced from a static context Java Basics - Anfänger-Themen 4
P non-static variable cannot be referenced from a static context Java Basics - Anfänger-Themen 6
A Wie zwei zahlen in einer Variable speichern? Java Basics - Anfänger-Themen 7
W Problem mit dem Wert von boolean-Variable Java Basics - Anfänger-Themen 3
M Input/Output JTextField Eingabe in String Variable speichern Java Basics - Anfänger-Themen 15
A Kann man eine Methode als Variable speichern und danach noch verändern? Java Basics - Anfänger-Themen 6
L cannot find symbol variable Kon Java Basics - Anfänger-Themen 8
C Statischer Typ aber Variable nicht statisch? Java Basics - Anfänger-Themen 5
H Variable.methode aufstellen, verstehen Java Basics - Anfänger-Themen 2
R Warnung, wenn eine Variable eingegeben wird Java Basics - Anfänger-Themen 6
S Variable einscannen Java Basics - Anfänger-Themen 30
N Best Practice Rückgabe eines Terminal Befehls in eine Variable speichern Java Basics - Anfänger-Themen 27
M Erste Schritte Mit Variable verschiedene Texte in Textfeld einfügen Java Basics - Anfänger-Themen 27
J Input-Variable nicht sichtbar Java Basics - Anfänger-Themen 2
L Warum ist Variable null? Java Basics - Anfänger-Themen 3
E Variable (Vektor) in andere Methode übergeben Java Basics - Anfänger-Themen 4
A OOP Variable in anderer Klasse durch Methode aufrufen und einer anderen Variable gleichsetzen Java Basics - Anfänger-Themen 2
S Variable Parameter Java Basics - Anfänger-Themen 5
P if - Statement erkennt variable nicht. Java Basics - Anfänger-Themen 12
J Ungewollte Wertveränderung einer Variable Java Basics - Anfänger-Themen 9
R Variablen Variable an FXML-Controller übergeben Java Basics - Anfänger-Themen 4
J Zugriff auf Variable in anderem Programm Java Basics - Anfänger-Themen 5
R variable istpositiv might not have been initialized Java Basics - Anfänger-Themen 2
A Methodenname aus variable Java Basics - Anfänger-Themen 2
L Variable aus einer Klasse in einer anderen Klasse nutzen Java Basics - Anfänger-Themen 6
P Methode soll Variable einer anderen Klasse ändern. Wie? Java Basics - Anfänger-Themen 1
Hanschyo Variable nicht initialisiert Java Basics - Anfänger-Themen 6
deatzi Variable aus If Abfrage später nutzen Java Basics - Anfänger-Themen 4
L Variable in If-Statement initialisieren Java Basics - Anfänger-Themen 4
C return kann nicht auf variable zugreifen Java Basics - Anfänger-Themen 26
S Wie erstelle ich eine Vorbedingung für eine Variable einer Methode ? Java Basics - Anfänger-Themen 5
S Warum kann ich nicht mehr als eine Variable in einer for Schleife deklarieren ? Java Basics - Anfänger-Themen 1
J Wert eines Arrays einer Variable zuweisen, sobald der Wert eines anderen Arrays eintritt Java Basics - Anfänger-Themen 2
DaCrazyJavaExpert Compiler-Fehler Variable nicht mit null initialisiert, trotzdem: NullPointerException Java Basics - Anfänger-Themen 28
A Erste Schritte Mein Programm erkennt die variable EinAus.readInt nicht Java Basics - Anfänger-Themen 15
Aprendiendo [JAVA-Syntax] (int... variable) bei einem Konstruktor Java Basics - Anfänger-Themen 8
F Variablen If else: Einer Variable einen Wert hinzufügen oder so? Java Basics - Anfänger-Themen 6
Aprendiendo Interpreter-Fehler "non-static variable this cannot be referenced from a static context" Java Basics - Anfänger-Themen 2
D Aufruf einer statischen Variable Java Basics - Anfänger-Themen 1
F [OOP] Auf eine Variable aus meherer Klassen zugreifen Java Basics - Anfänger-Themen 22
D Einer Variable automatisch Zahlen hinzuaadieren Java Basics - Anfänger-Themen 3
BadBat Klassen instanz als variable + methodenaufruf Java Basics - Anfänger-Themen 4
BadBat Variablen Eine Variable mit 2 Typen Java Basics - Anfänger-Themen 38
S Cannot find symbol (symbol ist eine Variable) Java Basics - Anfänger-Themen 13
K String einlesen und als Variable speichern Java Basics - Anfänger-Themen 8
M Variable noch erstellen oder lieber so? Java Basics - Anfänger-Themen 1

Ähnliche Java Themen

Neue Themen


Oben