Erstellen Sie eine Leiste für den Dialog zum Bearbeiten der Datensätze, in der unten im Dialog die Nummer des aktuellen Datensatzes und die Anzahl aller Datensätze angezeigt werden. Der Dialog mit der Leiste könnte ungefähr so aussehen:
Die Leiste zur Anzeige der Datensatznummer (unten am Mauszeiger)
Lassen Sie die Anzeige in der Leiste beim Navigieren und beim Löschen aktualisieren. Denken Sie beim Löschen daran, dass sich auch die Gesamtzahl verändert.
Ich habe den Code geschrieben funtioniert alles, ausser am anfang bei dem Datensatz zeigt er 1von 0 und soll 1 von 14 zeigen, ich sollte glaubich rowCount--; irgendwo schreiben aber ich habe nicht geschaft. Könnte jemand mir helfen
Danke im Voraus
Java:
import java.awt.BorderLayout;
import java.awt.GridLayout;
import java.awt.event.ActionEvent;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.sql.Connection;
import java.sql.ResultSet;
import javax.swing.AbstractAction;
import javax.swing.ImageIcon;
import javax.swing.JDialog;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JTextField;
import javax.swing.JToolBar;
import javax.swing.KeyStroke;
public class BearbeitenEintrag extends JDialog {
//automatisch über Eclipse erzeugt
private static final long serialVersionUID = 2674865770208476234L;
//für die Eingabefelder
private JTextField name, nachname, strasse, plz, ort, telefon;
//für die Anzeige
//für die Anzeige füge ich datensatz ein........Einsendeaufgabe nummer1
private JLabel nummer,datensatz;
//für die Aktionen
private MeineAktionen loeschenAct, vorAct, zurueckAct, startAct, endeAct, aktualisierenAct;
//für die Verbindung
private Connection verbindung;
private ResultSet ergebnisMenge;
// Counter zum Zählen der Datensätze
//...................................Einsendeaufgabe nummer 1
private int rowCount;
//für die Abfrage
private String sqlAbfrage;
//eine innere Klasse für die Aktionen
class MeineAktionen extends AbstractAction {
//automatisch über Eclipse ergänzt
private static final long serialVersionUID = 8673560298548765044L;
//der Konstruktor
public MeineAktionen(String text, ImageIcon icon, String beschreibung, KeyStroke shortcut, String actionText) {
//den Konstruktor der übergeordneten Klasse mit dem Text und dem Icon aufrufen
super(text, icon);
//die Beschreibung setzen für den Bildschirmtipp
putValue(SHORT_DESCRIPTION, beschreibung);
//den Shortcut
putValue(ACCELERATOR_KEY, shortcut);
//das ActionCommand
putValue(ACTION_COMMAND_KEY, actionText);
}
@Override
public void actionPerformed(ActionEvent e) {
if (e.getActionCommand().equals("vor"))
ganzVor();
if (e.getActionCommand().equals("zurueck"))
ganzZurueck();
if (e.getActionCommand().equals("einenvor"))
einenVor();
if (e.getActionCommand().equals("einenzurueck"))
einenZurueck();
if (e.getActionCommand().equals("loeschen"))
loeschen();
if (e.getActionCommand().equals("aktualisieren"))
aktualisieren();
}
}
//die innere Klasse für die Fensterereignisse
class FensterListener extends WindowAdapter {
@Override
public void windowClosing(WindowEvent e) {
super.windowClosing(e);
//die Datenbankverbindung trennen
//ergebnisMenge und verbindung sind Variablen der äußeren Klasse
try {
BearbeitenEintrag.this.ergebnisMenge.close();
BearbeitenEintrag.this.verbindung.close();
MiniDBTools.schliessenDB("jdbc:derby:");
}
catch(Exception exc) {
JOptionPane.showMessageDialog(null, "Problem: \n" + exc.toString());
}
}
}
//der Konstruktor der Klasse BearbeitenEintrag
public BearbeitenEintrag(JFrame parent, boolean modal) {
super(parent, modal);
setTitle("Einträge bearbeiten");
//wir nehmen ein Borderlayout
setLayout(new BorderLayout());
//die Aktionen erstellen
loeschenAct = new MeineAktionen("Datensatz löschen",
new ImageIcon("icons/Delete24.gif"),
"Löscht den aktuellen Datensatz",
null,
"loeschen");
vorAct = new MeineAktionen("Einen Datensatz weiter",
new ImageIcon("icons/Forward24.gif"),
"Blättert einen Datensatz weiter",
null,
"einenvor");
zurueckAct = new MeineAktionen("Einen Datensatz zurück",
new ImageIcon("icons/Back24.gif"),
"Blättert einen Datensatz zurück",
null,
"einenzurueck");
startAct = new MeineAktionen("Zum ersten Datensatz",
new ImageIcon("icons/Front24.gif"),
"Geht zum ersten Datensatz",
null,
"vor");
endeAct = new MeineAktionen("Zum letzten Datensatz",
new ImageIcon("icons/End24.gif"),
"Geht zum letzten Datensatz",
null,
"zurueck");
aktualisierenAct = new MeineAktionen("Änderungen speichern",
new ImageIcon("icons/Save24.gif"),
"Speichert Änderungen am aktuellen Datensatz",
null,
"aktualisieren");
//die Symbolleiste oben einfügen
add(symbolleiste(), BorderLayout.NORTH);
//die Oberfläche erstellen und einfügen
add(initGui(), BorderLayout.CENTER);
//zuerst nehmen wir alle Einträge aus der Tabelle adressen
sqlAbfrage = "SELECT * FROM adressen";
//diese Abfrage wählt nur alle Müllers aus
//sqlAbfrage = "SELECT * FROM adressen WHERE nachname = 'Müller'";
//die Datenbankverbindung herstellen
initDB();
//es werden die zeilen der datenbank gezählt.........Einsendeaufgabe nummer1
rowcount();
//die Verbindung mit dem Listener des Fensters herstellen
addWindowListener(new FensterListener());
//packen und anzeigen
pack();
setVisible(true);
//Standardoperation setzen
//hier den Dialog ausblenden und löschen
setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE);
}
//fügt die Felder in ein Panel ein und liefert das Panel zurück
private JPanel initGui() {
JPanel tempPanel = new JPanel();
//im GridLayout mit zwei Spalten
tempPanel.setLayout(new GridLayout(0, 2));
//für die Nummer (nur Anzeige)
tempPanel.add(new JLabel("ID-Nummer:"));
nummer = new JLabel();
tempPanel.add(nummer);
//für die anderen Felder
tempPanel.add(new JLabel("Vorname:"));
name = new JTextField();
tempPanel.add(name);
tempPanel.add(new JLabel("Nachname:"));
nachname = new JTextField();
tempPanel.add(nachname);
tempPanel.add(new JLabel("Strasse:"));
strasse = new JTextField();
tempPanel.add(strasse);
tempPanel.add(new JLabel("PLZ:"));
plz = new JTextField();
tempPanel.add(plz);
tempPanel.add(new JLabel("Ort:"));
ort = new JTextField();
tempPanel.add(ort);
tempPanel.add(new JLabel("Telefon:"));
telefon = new JTextField();
tempPanel.add(telefon);
//.................................................Einsendeaufgabe nummer 1
tempPanel.add(new JLabel("Datensatz:"));
datensatz = new JLabel();
tempPanel.add(datensatz);
//zurückgeben
return tempPanel;
}
//die Symbolleiste erzeugen und zurückgeben
private JToolBar symbolleiste() {
JToolBar leiste = new JToolBar();
//die Symbole über die Aktionen einbauen
leiste.add(loeschenAct);
leiste.add(aktualisierenAct);
//Abstand einbauen
leiste.addSeparator();
leiste.add(startAct);
leiste.add(zurueckAct);
leiste.add(vorAct);
leiste.add(endeAct);
//die komplette Leiste zurückgeben
return (leiste);
}
//die Verbindung zur Datenbank herstellen
private void initDB() {
try{
//Verbindung herstellen und Ergebnismenge beschaffen
verbindung=MiniDBTools.oeffnenDB("org.apache.derby.jdbc.EmbeddedDriver", "jdbc:derby:adressenDB");
ergebnisMenge = MiniDBTools.liefereErgebnis(verbindung, sqlAbfrage);
// rowCount vor Verwendung füllen--------Einsendeaufgabe nummer 1
ergebnisMenge.last();
rowCount = ergebnisMenge.getRow();
ergebnisMenge.beforeFirst();
if (ergebnisMenge.next())
datenLesen();
}
catch(Exception e) {
JOptionPane.showMessageDialog(this, "Problem: \n" + e.toString());
}
}
//die Methode liest die Daten und schreibt sie in die Felder
private void datenLesen() {
try {
nummer.setText(Integer.toString(ergebnisMenge.getInt(1)));
name.setText(ergebnisMenge.getString(2));
nachname.setText(ergebnisMenge.getString(3));
strasse.setText(ergebnisMenge.getString(4));
plz.setText(ergebnisMenge.getString(5));
ort.setText(ergebnisMenge.getString(6));
telefon.setText(ergebnisMenge.getString(7));
// Hier wird rowCount verwendet!...Einsendeaufgabe nummer1
datensatz.setText(ergebnisMenge.getRow()+"/"+ rowCount);
rowCount++;
// Ergänzung zum ermitteln der Datensätze und zum Anzeigen in der Gui
ergebnisMenge.getRow();
}
catch(Exception e) {
JOptionPane.showMessageDialog(this, "Problem: \n" + e.toString());
}
}
//diese methode zählt die reihen und setzt den zeiger wieder auf anfang.....Einsendeaufgabe nummer 1
private void rowcount() {
try {
ergebnisMenge.last();
rowCount = ergebnisMenge.getRow();
ergebnisMenge.beforeFirst();
}
catch(Exception e) {
JOptionPane.showMessageDialog(this, "Problem: \n" + e.toString());
}
}
//die Methode geht zum ersten Datensatz
private void ganzVor() {
try {
//gibt es noch einen Datensatz?
//ist das Ende erreicht?
//........................................Einsendeaufgabenummer2
if (ergebnisMenge.isLast() == false)
if (ergebnisMenge.next())
datenLesen();
}
catch(Exception e) {
JOptionPane.showMessageDialog(this, "Problem: \n" + e.toString());
}
}
//die Methode geht zum letzten Datensatz
private void ganzZurueck() {
try {
//ganz nach hinten gehen
ergebnisMenge.last();
datenLesen();
}
catch(Exception e) {
JOptionPane.showMessageDialog(this, "Problem: \n" + e.toString());
}
}
//die Methode geht einen Datensatz weiter
private void einenVor() {
try {
//gibt es noch einen Datensatz?
if (ergebnisMenge.next())
datenLesen();
}
catch(Exception e) {
JOptionPane.showMessageDialog(this, "Problem: \n" + e.toString());
}
}
//die Methode geht einen Datensatz zurück
private void einenZurueck() {
try{
//gibt es noch einen Datensatz davor?.........Einsendeaufgabe nummer2
if (ergebnisMenge.isFirst() == false)
if (ergebnisMenge.previous())
datenLesen();
}
catch(Exception e) {
JOptionPane.showMessageDialog(this, "Problem: \n" + e.toString());
}
}
//die Methode löscht einen Datensatz
private void loeschen() {
try {
//wir müssen uns merken, wo wir sind
int position;
position = ergebnisMenge.getRow();
//den Eintrag löschen
ergebnisMenge.deleteRow();
//Ergebnismenge schließen
ergebnisMenge.close();
// und neu öffnen
ergebnisMenge = MiniDBTools.liefereErgebnis(verbindung, sqlAbfrage);
//und wieder zur "alten" Position gehen
ergebnisMenge.absolute(position);
//stehen wir jetzt hinter dem letzten?
if (ergebnisMenge.isAfterLast())
//dann zum letzten gehen
ergebnisMenge.last();
//die Daten neu lesen
datenLesen();
}
catch(Exception e) {
JOptionPane.showMessageDialog(this, "Problem: \n" + e.toString());
}
}
//die Methode aktualisiert einen Eintrag
private void aktualisieren() {
try {
//wir müssen uns merken, wo wir sind
int position;
position = ergebnisMenge.getRow();
//die Daten aktualisieren
ergebnisMenge.updateString(2, name.getText());
ergebnisMenge.updateString(3, nachname.getText());
ergebnisMenge.updateString(4, strasse.getText());
ergebnisMenge.updateString(5, plz.getText());
ergebnisMenge.updateString(6, ort.getText());
ergebnisMenge.updateString(7, telefon.getText());
//den Datensatz aktualisieren
ergebnisMenge.updateRow();
//Ergebnismenge schließen
ergebnisMenge.close();
// und neu öffnen
ergebnisMenge = MiniDBTools.liefereErgebnis(verbindung, sqlAbfrage);
//und wieder zur "alten" Position gehen
ergebnisMenge.absolute(position);
//die Daten neu lesen
datenLesen();
}
catch(Exception e) {
JOptionPane.showMessageDialog(this, "Problem: \n" + e.toString());
}
}
}
Lassen Sie die Anzeige in der Leiste beim Navigieren und beim Löschen aktualisieren. Denken Sie beim Löschen daran, dass sich auch die Gesamtzahl verändert.
Ich habe den Code geschrieben funtioniert alles, ausser am anfang bei dem Datensatz zeigt er 1von 0 und soll 1 von 14 zeigen, ich sollte glaubich rowCount--; irgendwo schreiben aber ich habe nicht geschaft. Könnte jemand mir helfen
Danke im Voraus
Zuletzt bearbeitet von einem Moderator: