Heiner KückerJDBC Schlüssel Generierung |
|
Home Java-Seite Bit Packed Array ASM Improved heterogene Map, HMap Constraint Code Generator JSP WorkFlow PageFlow FlowControl Page Flow Engine Web Flow Engine Control_and_Command JSP_Spreadsheet Code-Generator für Option-Either-Stil in Java verbesserter Comparator Fluent-Interface Code-Generator auf Basis einer Grammatik Visitor mit Multidispatch for-Schleife mit yield-return Kognitions-Maschine semantisches Netz Domain Parser Codegenerator_für hierarchische Datenstrukturen Expression_Engine Formula_Parser Thread Preprocessor State Transition Engine AspectJ Java_Explorer DBF_Library Kalender_Applet SetGetGen BeanSetGet CheckPackage LineNumbers GradDms Excel-Export StringTokenizer JspDoc JspCheck JSP-Schulung Java Server Pages Struts Ascii-Tabellen- Layouter Ascii-Baum- Layouter Ascii-Art-Fluss- Diagramm- Parser AsciiArt AssignmentMatrix Layouter StringSerial Silbentrennung JDBC_Schlüssel- Generierung bidirektional/ unidirektional gelinkte Liste Java_Sitemap Generator XmlBuilder RangeMap StringFormatter VersionSafe XCopy JTextField CommandLine- ParamReader Bitmap-Grafik MultiMarkable- Buffered- InputStream JavaCache JdomUtil CollectionUtil XML Really Pull Parser Log-Filter Remote-Protokoll Sudoku-Generator Delegation statt Mehrfachvererbung Disjunct Interval Set WebCam_Demo Weiterentwicklung_Java Alaska-XBase++-Seite Projekte Philosophien Techniken Konzepte Sudoku Kontakt / Impressum Links SiteMap Letzte Aktualisierung: 07.12.2004 |
Primery Key Erzeugung für JDBC älter als Version 3.0Primery Key Generation for JDBC lesser than 3.0
Als eindeutiger Schlüssel für die Datensätze in der Datenbank
wird eine bei eins beginnende laufende Nummer verwendet.
ResultSet rs = stmt.getGetGeneratedKeys();zur Verfügung. Damit kann der von der Datenbank über AUTOINCREMENT erzeugte Key abgefragt werden. Nutzer einer älteren JDBC-Schnittstelle müssen sich selbst um die Schlüssel-Erzeugung kümmern. Es gibt Anleitungen oder Best Practices Vorschläge, die mit Vergabe von Schlüsselgruppen und anderen Kompliziertheiten arbeiten. Für meinen Fall war der kleine synchronized-Block, durch den alle abfragenden Threads laufen müssen, kein Problem. Deshalb habe ich eine ganz einfache Lösung gewählt. Da dieser kleine synchronized-Block einen Datenbankzugriff enthält, kann er unter Umständen mehrere Sekunden laufen. So lange blockiert der KeyGenerator. Dies tritt nur beim ersten Zugriff nach dem Neustart der Applikation auf. Alternativ müsste man den KeyGenerator mit den Namen aller Datenbanken und Tabellen initialisieren. Das verlangsamt aber den Start der Applikation evtl. gewaltig. Alle (zu schreibenden) Tabellen müssen ein INTEGER-, BIGINT- oder DECIMAL-Feld zum Tragen der Ident-Nummer haben. Der Feldname ist konfigurierbar, es sollte aber ein einheitlicher Name, zum Beispiel 'ID' gewählt werden. Die Key's (in diesem Fall long-Werte bei eins beginnend) werden in einer HashMap, welche vom Tabellen-Namen auf den Key-Merker (innere Klasse KeyEntry) mappt, gehalten. Falls für die abgefragte Tabelle noch kein KeyEntry exisitert, wird dieser über ein SQL-Statement SELECT MAX( <field> ) FROM <table>ermittelt. In der Klasse KeyEntry wird ein long-Wert als Merker für den letzten vergebenen Key gehalten, was nach verbreiteten Performance-Empfehlungen als günstiger gegenüber dem ständigen Erzeugen und Verwerfen von Long-Objekten gilt. Nachgemessen habe ich es nicht. Die Keygenerator-Klasse ist für die Arbeit mit mehreren Datenbanken ausgelegt. Aufgrund der Einschränkung, dass immer nur ein JDBC-Treiber in der JVM geladen werden kann, müssen diese vom gleichen Hersteller und in der Version identisch sein. Falls Sie nur eine Datenbank in ihrer Anwendung ansprechen, können Sie die Variable dbMemoryKeyMap entfernen. !!! Achtung Achtung Achtung !!! Dieser einfache KeyGenerator funktioniert nur, wenn ausschliesslich aus der VM-Instanz auf die Datenbank schreibend zugegriffen wird, in welcher dieser Code läuft. A small class for generation a unique primery key for database records to identification. Download der Quelldateien KeyGen.zip Lies bitte hierzu auch den Thread auf Newsgroup de.comp.lang.java zu diesem Thema.
Achtung: Erweiterungen und Fixes stelle ich ohne Historie
und ohne Ankündigung hier bereit. Lizenzbedingungen:
Die Programme, Quelltexte und Dokumentationen können ohne
irgendwelche Bedingungen kostenlos verwendet werden. |