Heim Java javaLernprogramm Spring dynamische Konfiguration mehrerer Datenquellen

Spring dynamische Konfiguration mehrerer Datenquellen

Jan 24, 2017 am 10:38 AM

In letzter Zeit haben viele Leute gefragt, wie man im Frühjahr mehrere Datenquellen konfiguriert, und es ist schwierig, sie einzeln zu beantworten. Darüber hinaus gab es in früheren Blog-Beiträgen auch Probleme mit der Konfiguration, daher veröffentliche ich eine erneut Demo für alle.

Die Demo enthält zwei Datenquellen, nämlich MySQL und Oracle. Es gibt kein Problem beim dynamischen Wechseln der Datenquellen.

Darüber hinaus werde ich einige Anweisungen geben, um die wichtigsten Punkte bei der Konfiguration mehrerer Datenquellen zu erläutern:

1. Achten Sie auf die Konfiguration des Transaktions-Interceptors

Das ist in erster Linie. Zunächst müssen Sie verstehen, dass die Transaktionsverwaltung von Spring an die Datenquelle gebunden ist, sobald das Programm an die Transaktionsverwaltungsschicht (z. B. einen Dienst) ausgeführt wird, da die Transaktion über den Interceptor geöffnet wurde, bevor sie in diese Schicht eintritt In dieser Schicht ist es nicht möglich, die Datenquellen zu wechseln. In meinem vorherigen Artikel gab es ein Problem mit der Konfiguration des Interceptors für den Wechsel der Datenquellen in der Dao-Schicht (da es sich um ein Beispiel handelte). Ich war also nachlässig und habe mich in die Irre geführt (ich entschuldige mich bei allen), aber die bereitgestellten Ideen sind nicht problematisch.

In der Demo ist der Interceptor zum Wechseln von Datenquellen (dataSourceInterceptor) auf der oberen Ebene des Transaktions-Interceptors (txadvice) konfiguriert, der Controller-Ebene.

2. Achten Sie auf die Erstellung von Datenbanktabellen

Manche Leute nutzen gerne die Funktion des Ruhezustands zum automatischen Erstellen von Tabellen, es muss jedoch beachtet werden, dass dies bei mehreren Daten der Fall ist Quellen, insbesondere unterschiedliche Es ist unmöglich, automatisch Tabellen für alle verschiedenen Datenquellen in der Datenbank zu erstellen. Da die automatische Tabellenerstellung von Hibernate beim Start des Projekts ausgelöst wird, werden nur die Tabellen der im Projekt konfigurierten Standarddatenquelle erstellt und Tabellen aus anderen Datenquellen werden nicht automatisch erstellt. Jeder sollte aufpassen.

3. Der Datenbankdialekt (Dialekt) von Hibernate kann ignoriert werden

Bei Verwendung mehrerer Datenquellen kann die Dialekteinstellung ignoriert werden und Hibernate erkennt automatisch verschiedene, wenn Verwenden Sie diese Datenbank, sodass Sie sich um diese Konfiguration keine Gedanken machen oder sie gar nicht konfigurieren müssen.

4. Kein aktueller Sitzungsfehler melden

Dies wird durch die Verwendung von sessionFactory.getCurrentSession() verursacht. Die aktuelle Sitzung ist nur an einen Thread gebunden wird geöffnet (es wird kein Fehler gemeldet, es sei denn, openSession() wird verwendet), daher muss die Bindungsbeziehung zwischen der Sitzung und dem Thread festgelegt werden.
Spring wird zum Verwalten von Hibernate-Sitzungen in der Demo verwendet, daher ist OpenSessionInViewFilter in web.xml und current_session_context_class in hibernate.cfg.xml konfiguriert. [PS: Wenn Sie Spring zum Verwalten von Hibernate verwenden, können Sie hibernate.cfg.xml entfernen. Alle Konfigurationen befinden sich in der Spring-Konfigurationsdatei, dh hibernateProperties. Das hängt von den persönlichen Vorlieben ab.】

Schließlich integriert die Demo einfach einige Frameworks, die jeder nutzen kann, was für alle von Vorteil ist. Die Konfiguration und Technologie dieser Frameworks wird hier nicht näher erläutert.

Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, dass er zum Lernen aller beiträgt. Ich hoffe auch, dass jeder die PHP-Chinesisch-Website unterstützt.

Weitere Artikel zur dynamischen Konfiguration mehrerer Datenquellen in Spring finden Sie auf der chinesischen PHP-Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Top 4 JavaScript -Frameworks in 2025: React, Angular, Vue, Svelte Top 4 JavaScript -Frameworks in 2025: React, Angular, Vue, Svelte Mar 07, 2025 pm 06:09 PM

Dieser Artikel analysiert 2025 die vier besten JavaScript -Frameworks (React, Angular, Vue, Svelte) und verglichen ihre Leistung, Skalierbarkeit und Zukunftsaussichten. Während alle aufgrund starker Gemeinschaften und Ökosysteme dominant bleiben, sind ihr relatives Popul

Wie implementiere ich mehrstufige Caching in Java-Anwendungen mit Bibliotheken wie Koffein oder Guava-Cache? Wie implementiere ich mehrstufige Caching in Java-Anwendungen mit Bibliotheken wie Koffein oder Guava-Cache? Mar 17, 2025 pm 05:44 PM

In dem Artikel wird in der Implementierung von mehrstufigem Caching in Java mithilfe von Koffein- und Guava-Cache zur Verbesserung der Anwendungsleistung erläutert. Es deckt die Einrichtungs-, Integrations- und Leistungsvorteile sowie die Bestrafung des Konfigurations- und Räumungsrichtlinienmanagements ab

Spring Boot Snakeyaml 2.0 CVE-2022-1471 Problem behoben Spring Boot Snakeyaml 2.0 CVE-2022-1471 Problem behoben Mar 07, 2025 pm 05:52 PM

Dieser Artikel befasst sich mit der Verwundbarkeit von CVE-2022-1471 in Snakeyaml, einem kritischen Fehler, der die Ausführung von Remote-Code ermöglicht. Es wird beschrieben

Wie funktioniert der Klassenladungsmechanismus von Java, einschließlich verschiedener Klassenloader und deren Delegationsmodelle? Wie funktioniert der Klassenladungsmechanismus von Java, einschließlich verschiedener Klassenloader und deren Delegationsmodelle? Mar 17, 2025 pm 05:35 PM

Mit der Klassenbelastung von Java wird das Laden, Verknüpfen und Initialisieren von Klassen mithilfe eines hierarchischen Systems mit Bootstrap-, Erweiterungs- und Anwendungsklassenloadern umfasst. Das übergeordnete Delegationsmodell stellt sicher

Node.js 20: wichtige Leistungssteigerung und neue Funktionen Node.js 20: wichtige Leistungssteigerung und neue Funktionen Mar 07, 2025 pm 06:12 PM

Node.js 20 verbessert die Leistung durch V8 -Motorverbesserungen erheblich, insbesondere durch schnellere Müllsammlung und E/A. Zu den neuen Funktionen gehören eine bessere Support von WebAssembly und raffinierte Debugging -Tools, die Produktivität der Entwickler und die Anwendungsgeschwindigkeit.

ICEBERG: Die Zukunft von Data Lake Tabellen ICEBERG: Die Zukunft von Data Lake Tabellen Mar 07, 2025 pm 06:31 PM

Iceberg, ein offenes Tabellenformat für große analytische Datensätze, verbessert die Leistung und Skalierbarkeit von Data Lake. Es befasst sich mit Einschränkungen von Parquet/ORC durch internes Metadatenmanagement und ermöglicht eine effiziente Schemaentwicklung, Zeitreisen, gleichzeitiger W

Wie kann ich funktionale Programmierungstechniken in Java implementieren? Wie kann ich funktionale Programmierungstechniken in Java implementieren? Mar 11, 2025 pm 05:51 PM

In diesem Artikel wird die Integration der funktionalen Programmierung in Java unter Verwendung von Lambda -Ausdrücken, Streams -API, Methodenreferenzen und optional untersucht. Es zeigt Vorteile wie eine verbesserte Lesbarkeit der Code und die Wartbarkeit durch SUKTIVE UND VERUSNAHMETALITÄT

So teilen Sie Daten zwischen Schritten in der Gurke So teilen Sie Daten zwischen Schritten in der Gurke Mar 07, 2025 pm 05:55 PM

In diesem Artikel werden Methoden zum Austausch von Daten zwischen Gurkenschritten und dem Vergleich des Szenario -Kontextes, globalen Variablen, Argumentenübergabe und Datenstrukturen untersucht. Es betont Best Practices für Wartbarkeit, einschließlich präziser Kontextgebrauch, beschreibend

See all articles