SqlObject - eine objektorientierte Art SQL-Statements zu schreiben.

scaphare

Neues Mitglied
Hallo Miteinander,

ich habe ein Paket geschrieben, mit dem SQL Statements geschrieben werden können. Und zwar objektorientiert.
Per Adapter können die Ausgaben unterschiedlichen Bedürfnissen angepasst werden.
Unten habe ich mal einen Auszug aus meinem Eclipse-Projekt angehängt.

Die Main-Klasse enthält ein Beispiel, um die Funktionsweise aufzuzeigen.
Das Sql-Paket ist von mir so angelegt, dass die Statements fließend geschrieben werden können.
Der vorliegende Auszug unterstützt MySQL und SQLite. Ich habe desweiteren Adapter geschrieben, um Jasper Reports - oder iText - Ausgaben zu erzeugen. Aus exemplarischen Gründen habe ich nur den Adapter ConsoleTable beigefügt, um die Funktionsweise zu verdeutlichen.

Falls die Beispielausgaben nicht erzeugt werden, dann fehlt wohl die sqlitejdbc Bibliothek.
Die kann hier heruntergeladen werden.

Bitte schreibt mir, ob es sinnvoll ist, diesen Entwicklungspfad weiterzuverfolgen.
Ich bitte, um konstruktive Kritik, die sich konzeptionell mit der Thematik auseinandersetzt.

Zum Download von SqlObject

(Programmiertechnische Anmerkungen bitte ich zurückzustellen, da es sich hier um einen ersten Prototypen handelt.)


Ein Beispiel:

PHP:
package anywheresoftware.b4a.tsqlobject;

import java.security.SecureRandom;
import java.math.BigInteger;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;

import anywheresoftware.b4a.inspector.inspect.*;

import anywheresoftware.b4a.tadapter.*;
import anywheresoftware.b4a.BA.ShortName;

@ShortName("Main")
public class Main {

	public static void main(String[] args) throws Exception {

		Config.getInstance().register("connection.default", "jdbc:sqlite:data/migli.db");
		Config.getInstance().register("connection.driver", "org.sqlite.JDBC");
		
		String str = new BigInteger(130, new SecureRandom()).toString(4);
		String str2 = new BigInteger(130, new SecureRandom()).toString(8);
		
		DateFormat df = new SimpleDateFormat("yyyy-MM-dd H:m:s");
		Date today = Calendar.getInstance().getTime();
		String CreatedAt = df.format(today);
		
		SqlInsert ins = new SqlInsert();
		ins.into("users");
		ins.column("user_name").value("tsc" + str);
		ins.column("user_pass").value("pw"+str2);
		ins.column("is_active").value(1);
		ins.column("is_deleted").value(0);
		ins.column("created_at").value(CreatedAt);
		
		try {		
			System.out.println(ins.Execute());
		} catch(Exception e) {
			e.printStackTrace();			
		}
		
		
		SqlSelect s = new SqlSelect();
		s.from("users");
		
		try {
			System.out.println(s.toString());
			System.out.println(s.Execute().save(new ConsoleTable()));
			
		} catch (Exception e) {
			e.printStackTrace();
		}
	    
	}

}
 

turtle

Top Contributor
Zunächst finde ich es bemerkenswert wie Du dir Gedanken über eine objekt-orientierte Schale zum Absenden von SQL-kommandos gemacht hast. Der Code sieht auch ganz gut und lesbar aus.

Aber...

Bitte schreibt mir, ob es sinnvoll ist, diesen Entwicklungspfad weiterzuverfolgen.

Da bin ich leider anderer Ansicht. Dieses "Problem" wurde bereits mehrmals in sehr guter Manier in verschiedenen Frameworks eingesetzt. Die eine Linie von O/R-Mapper geht von der Annahme aus, dass der Entwickler von SQL-Kommandos nichts (bzw. wenig) zu sehen bekommt und dieses vom Framework erledigt werden soll. Zu dieser Philiosophie zählen zum Beispiel Hibernate oder JPA.

Eine weitere Linie versucht die Benutzung von SQL-Kommandos zu vereinfachen. Hierzu zählt besipielsweise mein Lieblings-Framework myBATIS. Bei diesem ist der Vorteil, entgegen zu Deinem Ansatz, dass der SQL-Befehl praktisch unverändert angewendet werden kann und die Ergebnisse (Resultset) auf Java-Objekte gemapped werden können. Dieses ist aus meiner Erfahrung ein guter Ansatz, weil Leute, die sich mit DB besser auskennen (als ich) eigentlich immer auf SQL-Ebene denken und reden. Dein Ansatz dagegen ist scheint mir ein Zwitter zu sein, denn weder ein DBA noch ein Java-Kenner sehen das SQL-Kommando, das da abgesetzt werden soll, direkt. Hier sehe ich noch Potential, dass Du zum Beispiel im Bereich Logging etwas tun könntest.

Daher sehe ich wenig Gründe, warum ich Deinem Ansatz folgen sollte, denn wie gesagt, ich sehe das SQL-Kommando erst zur Laufzeit, schlecht für Diskussionen mit DBA's, und zum Optimieren muss ich Java-Code schreiben und ändern.
 

mvitz

Top Contributor
Die Frage ist auch, welche Vorteile deine Library gegenüber ausgereiften Lösungen hat, die dasselbe Ziel haben.

jOOQ - jOOQ : A peace treaty between SQL and Java
Querydsl

Die Arbeit, die du dir bisher gemacht hast, ist mit Sicherheit gut gewesen, alleine für das eigene Verstädnniss, die Frage ist eben nur, ob neben diesem Lerneffekt es jetzt noch Sinn macht, viel Energie in etwas zu stecken, wo es eben schon ausgereifte Lösungen gibt. (Ganz im Sinne von: "Don't reinvent the wheel.") Die Antwort kannst allerdings nur du selbst dir geben.
 

ARadauer

Top Contributor
Muss mich meinen Vorrednern anschließen.. schaut nett aus.. du bist aber nicht der erste der sich darüber Gedanken gemacht hat... wenn man sich ansieht wie weit zb schon spring data jpa ist, würd ich da nicht mehr viel Engergie investieren...
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
B Wie kann ich eine Jtable mit Inhalt einer SQL Abfrage füllen Datenbankprogrammierung 14
I SaaS Applikation: pro Kunde eine Datenbank / Schema oder eine DB für alle Kunden? Datenbankprogrammierung 76
Zrebna PostgreSQL-Query in eine MicrosoftSQL-Query konvertieren - chatGPT hilft nur bedingt. Datenbankprogrammierung 3
T Spring MongoDB: Prüfen ob bereits eine Email existiert Datenbankprogrammierung 15
Zrebna Wie mittels Hibernate eine Join-Tabelle als eigene Java-Klasse erstellen? Datenbankprogrammierung 5
Zrebna Probleme bei Überführung von SQL-Code in eine HQL-Abfrage Datenbankprogrammierung 3
Zrebna Wie mittels PL/SQL eine Datenbankverbindung blockieren? Datenbankprogrammierung 6
berserkerdq2 Was genau muss ich bei date eingeben, wenn ich in Java eine Spalte definiere, die date ist? Datenbankprogrammierung 1
pkm PostgreSQL Kann mit mybatis einen Parameter für eine postgreSQL-Abfrage nicht übergeben. Datenbankprogrammierung 5
Kirby.exe Eine Tabelle updaten Datenbankprogrammierung 16
B Wie kopieren ich eine Spalte von einer Tabelle in eine andere Tabelle SQLite durch java code? Datenbankprogrammierung 26
Z Aus zwei bestehenden Table eine zusätzliche Gemeinsame machen (JavaFX) Datenbankprogrammierung 21
Avalon Attribute werden mit Unterstrich in eine MySQL Datenbank eingetragen Datenbankprogrammierung 10
pkm PostgreSQL Auf eine Spalte kann aus einem Teil der SQL-Aussage nicht zugegriffen werden Datenbankprogrammierung 3
F Mapping einer SQL Abfrage in eine Klasse Datenbankprogrammierung 4
H suche eine Login system Bibliothek für Java Datenbankprogrammierung 5
C Datenbank anlegen und über eine Website mit Daten füllen? Datenbankprogrammierung 25
G Eine Spalte in xampp als Typ array erstellen - ein array mit "insert" hinzufügen. Datenbankprogrammierung 3
F Create Table - Habe ich eine schwache Entität erzeugt ? Datenbankprogrammierung 4
Dimax MySQL Trigger für eine Spalte Datenbankprogrammierung 5
Dimax MySQL Maximale Datenlänge für eine Spalte einer Datenbank in java ermitteln Datenbankprogrammierung 15
D MySQL Eibinden des "mysql-connector" in eine fertige Jar Datenbankprogrammierung 3
P JSP - Daten aus 2 Tabellen in eine neue Tabelle einfügen Datenbankprogrammierung 1
P Daten in eine mySQL Datenbank einfügen Datenbankprogrammierung 4
S MySQL JTable zeigt nach Datenbankabfrage eine Spalte zu viel an Datenbankprogrammierung 0
Thallius MySQL Tabelle splitten aber wie eine abfragen? Datenbankprogrammierung 10
B MySQL Eine Art Sverweis Datenbankprogrammierung 27
O HSQLDB Eine Entität, mehrere Tabellen Datenbankprogrammierung 8
B SQL-Statement Prüfen ob eine Spalte einen Wert enthält Datenbankprogrammierung 2
X SQLite Erhalte bei Query INSERT INTO eine NullPointerException Datenbankprogrammierung 10
L0MiN Wie kann ich eine bestimmte Seite aus verschiedenen Excel-Tabellen in eine neue Exceldatei kopieren? Datenbankprogrammierung 1
N Wie in Java Zugriffe und Updates auf eine Datenbank regeln ? Datenbankprogrammierung 1
E Wie kann ich aus diesem XML eine XMLTABLE-Funktion bauen? Datenbankprogrammierung 3
E Wie kann man mit einer ID-Spalte über eine Parameterübergabe auf eine Seite verweisen? Datenbankprogrammierung 17
A Eine MySQL Zeile mit JDBC löschen Datenbankprogrammierung 5
M Warum ist es suboptimal viele Indexe auf eine Datenbanktabelle zu setzen? Datenbankprogrammierung 4
L Datenmodell erstellen für eine Nutzertanalyse Datenbankprogrammierung 1
serjoscha MySQL Eine Instanz von eigenem DBWrapper -> Fehler durch mehrfachbenutzung möglich? Datenbankprogrammierung 2
S HSQLDB Verbieten eines update auf eine bestimmte reihe Datenbankprogrammierung 4
V HSQLDB Insert in eine Tabelle mit Autoincrement Datenbankprogrammierung 2
H Grosse Menge an Daten in eine Datenbank Datenbankprogrammierung 32
P MySQL eine richtige Datenbank für einen routenplaner erstellen Datenbankprogrammierung 2
D SQL Update auf eine Query möglich? Datenbankprogrammierung 4
C Mit jsp über Java eine DB Abfrage durchführen --> java.lang.ClassNotFoundException Datenbankprogrammierung 4
K SQLite CSV-Datei einlesen in eine Datenbank Datenbankprogrammierung 7
E Datenbank Abfragen in eine GUI schreiben Datenbankprogrammierung 8
A Problem mit Eintragen von Daten in eine Datenbank mittels DAO Datenbankprogrammierung 4
L MySQL MySql in eine Application einbinden? Datenbankprogrammierung 18
R MySQL Voraussetzungen für eine erfolgreiche Datenbankanbindung mittels JDBC Datenbankprogrammierung 2
H Derby/JavaDB Eine verschlüsselte Derby-Datenbank wieder entschlüsseln Datenbankprogrammierung 4
D Was passiert bei absolut zeitgleichem Zugriff auf eine Tablerow Datenbankprogrammierung 7
I Belastet es das System zu sehr einen Timer jede 0.2 Sekunden eine DB Abfrage machen zu lassen? Datenbankprogrammierung 9
I Zugriff auf eine Datenbank auf dem Webserver Datenbankprogrammierung 2
F H2:Wie kann man insert eine Reihe "int" wert als blob in table? Datenbankprogrammierung 12
J mal wieder eine Frage zu parallelen Transaktionen.. Datenbankprogrammierung 2
Screen Ich suche eine SQLDatenbank ohne JDBC-Treiber Datenbankprogrammierung 12
H Derby/JavaDB SQLException wenn die Datenbank in eine Jar gepackt wurde. Datenbankprogrammierung 6
turmaline [Hibernate] @OneToMany - Eine referenzierte Tabelle abfragen Datenbankprogrammierung 11
S Werte aus Datenbank auslesen und in eine bestimmte Excelzelle eintragen Datenbankprogrammierung 2
T Wer kann mir eine Datenbank empfehlen Datenbankprogrammierung 13
DStrohma MS SQL Server 2005 + Java: Immer nur eine aktive Verbindung erlaubt? Datenbankprogrammierung 5
D MySQL Wie schreibe ich in eine Datenbank? Datenbankprogrammierung 8
J String[] in eine SQL-Anweisung implementieren Datenbankprogrammierung 13
Q Access Datenbank in eine Internetseite einbinden Datenbankprogrammierung 2
J Über einen Button eine SQL-DB aussuchen Datenbankprogrammierung 3
O eine Tabelle hat mehrere PrimKey mit dem selben Wert Datenbankprogrammierung 9
R Connection Problem für eine externe DB mit Java (JDBC) Datenbankprogrammierung 9
M Zugriff auf eine Access-Datenbank innerhalb eines jar-Files Datenbankprogrammierung 7
N Wie kann ich Zugriff auf eine MS Access DB (mit JDBC) über Netzwerk erreichen? Datenbankprogrammierung 7
G Wie sieht eine Datenbankverbindung mit jndi aus? Datenbankprogrammierung 3
T eine Datenbank updaten Datenbankprogrammierung 6
C Prüfen, ob eine MySQL-Tabelle bereits existiert Datenbankprogrammierung 7
E Wie auf eine MySql Datenbank zugreifen Datenbankprogrammierung 25
D Werte mit java programm in eine Datenbank einlesen Datenbankprogrammierung 7
T JPQL Query für eine Tabellenansicht Datenbankprogrammierung 2
B Wie persistiert man eine Tree-ähnliche Datenbankstruktur? Datenbankprogrammierung 2
M Aus einem Applet eine Datenbankverbindung starten? Datenbankprogrammierung 26
R Datenbankstruktur für eine renn simulation Datenbankprogrammierung 3
H Wie kann ich eine Datenbank Connection aus XML-Datei lesen! Datenbankprogrammierung 2
G Wie baut man eine Anwendung mit DB Zugriff Datenbankprogrammierung 3
S Als Rückgebewert eine Liste von Werten? Datenbankprogrammierung 3
A Auslesen von Werten aus der DB in eine csv-Datei Datenbankprogrammierung 4
O Oracle 11g wirft bei 90 % der installation eine Exception ? Datenbankprogrammierung 5
T Recordsets in eine JTable einlesen mit Netbeans 6.0 Datenbankprogrammierung 2
R Warum kommt eine Exception bei instanceof ? Datenbankprogrammierung 4
M Tabelle von einer Datenbank in eine Andere Datenbankprogrammierung 4
G Inhalt eine Clob Feldes zw. zwei DB's kopieren Datenbankprogrammierung 2
A Einlesen einer csv-Datei in eine H2-Datenbank Datenbankprogrammierung 3
A Kriterium für eine JList neu definieren Datenbankprogrammierung 3
A Probleme beim Schreiben in eine CSV-Datei aus einer H2-DB Datenbankprogrammierung 2
G Import einer csv-Datei in eine H2-Database Datenbankprogrammierung 12
J Warum ist es aufwendig eine Datenbankverbindung herzustellen Datenbankprogrammierung 3
M Mit Java .txt-Datei in eine Datenbank einlesen lassen Datenbankprogrammierung 33
S Zugriff auf eine große Datenmenge von MS Access per JDBC Datenbankprogrammierung 11
S von einer DB auf eine andere Zugreifen. Datenbankprogrammierung 2
W Wann ist eine Telefonnummer atomar ? Datenbankprogrammierung 3
D Dateien in eine OODB abspeichern Datenbankprogrammierung 3
A Eine einzelne Zeile schreibschützen im DataSet Datenbankprogrammierung 13
E 2 Tabellen anhand eine Spalte zusammenführen? Datenbankprogrammierung 5
M GUI für eine Datenbank Datenbankprogrammierung 2

Ähnliche Java Themen


Oben