Heim Datenbank MySQL-Tutorial atitit.springhibernate的事务机制spring不能保存对象的解决

atitit.springhibernate的事务机制spring不能保存对象的解决

Jun 07, 2016 pm 04:13 PM
s 事务 机制

在Spring中使用Hibernate,如果我们配置了TransactionManager,那么我们就不应该调用SessionFactory的openSession()来获得Sessioin,因为这样获得的Session并没有被事务管理。 采用getCurrentSession()创建的session会绑定到当前线程中,而采用openSession()

在Spring中使用Hibernate,如果我们配置了TransactionManager,那么我们就不应该调用SessionFactory的openSession()来获得Sessioin,因为这样获得的Session并没有被事务管理。

采用getCurrentSession()创建的session会绑定到当前线程中,而采用openSession()创建的session则不会。

采用getCurrentSession()创建的session在commit或rollback时会自动关闭,而采用openSession()创建的session必须手动关闭。

使用getCurrentSession()需要在hibernate.cfg.xml文件中加入如下配置:

* 如果使用的是本地事务(jdbc事务)

thread

* 如果使用的是全局事务(jta事务)

jta

如果采用的时Hibernate4,使用getCurrentSession()必须配置事务,否则无法取到session

3 hibernateTemplate.getSessionFactory().getCurrentSession()

我们使用spring和hibernate结合,操作数据库最常用可能是HibernateTemplate,HibernateTemplate中集成了很多使用的方法,可惜的是没的createQuery方法,也许我们使用hibernate的时候喜欢使用Query,我们可能会封装hibernateTemplate.getSessionFactory().getCurrentSession()方法得到Session,session创建Query,这是一个方法,但你应该会得到异常 “createQuery without an active transaction”,因为使用hibernateTe【本文来自鸿网互联 (http://www.68idc.cn)】mplate.getSessionFactory().getCurrentSession(),你是使用的hibernate的事务管理,而你指望spring管理的事务是hibernateTemplate,所以你会提示没有打开事务的异常,解决方法:1)使用hibernate事务处理,就像上面单独使用hibernate一样,但这也许不是你想要的。2)使用hibernateTemplate的HibernateCallBack回调:

使用Hibernate的大多数应用程序需要某种形式的“上下文相关的” session,特定的session在整个特定的上下文范围内始终有效。然而,对不同类型的应用程序而言,要为什么是组成这种“上下文”下一个定义通常 是困难的;不同的上下文对“当前”这个概念定义了不同的范围。在3.0版本之前,使用Hibernate的程序要么采用自行编写的基于 ThreadLocal的上下文session,要么采用HibernateUtil这样的辅助类,要么采用第三方框架(比如Spring或Pico), 它们提供了基于代理(proxy)或者基于拦截器(interception)的上下文相关session。

从3.0.1版本开 始,Hibernate增加了SessionFactory.getCurrentSession()方法。一开始,它假定了采用JTA事务,JTA事务 定义了当前session的范围和上下文(scope and context)。Hibernate开发团队坚信,因为有好几个独立的JTA TransactionManager实现稳定可用,不论是否被部署到一个J2EE容器中,大多数(假若不是所有的)应用程序都应该采用JTA事务管理。 基于这一点,采用JTA的上下文相关session可以满足你一切需要。

更好的是,从3.1开 始,SessionFactory.getCurrentSession()的后台实现是可拔插的。因此,我们引入了新的扩展接口 (org.hibernate.context.CurrentSessionContext)和新的配置参数 (hibernate.current_session_context_class),以便对什么是“当前session”的范围和上下文(scope and context)的定义进行拔插。

 

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

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

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)

Sperrwartezeitüberschreitung überschritten; versuchen Sie, die Transaktion neu zu starten – So beheben Sie den MySQL-Fehler: Transaktionswartezeitüberschreitung Sperrwartezeitüberschreitung überschritten; versuchen Sie, die Transaktion neu zu starten – So beheben Sie den MySQL-Fehler: Transaktionswartezeitüberschreitung Oct 05, 2023 am 08:46 AM

Lockwaittimeoutexceeded;tryrestartingtransaction – So beheben Sie den MySQL-Fehler: Transaktionswartezeitüberschreitung Bei Verwendung der MySQL-Datenbank kann es manchmal zu einem häufigen Fehler kommen: Lockwaittimeoutexceeded;tryrestartingtransaction. Dieser Fehler weist auf eine Transaktionswartezeitüberschreitung hin. Dieser Fehler tritt normalerweise auf, wenn

MySQL-Transaktionsverarbeitung: Der Unterschied zwischen automatischer Übermittlung und manueller Übermittlung MySQL-Transaktionsverarbeitung: Der Unterschied zwischen automatischer Übermittlung und manueller Übermittlung Mar 16, 2024 am 11:33 AM

MySQL-Transaktionsverarbeitung: Der Unterschied zwischen automatischer Übermittlung und manueller Übermittlung. In der MySQL-Datenbank ist eine Transaktion eine Reihe von SQL-Anweisungen. Entweder sind alle Ausführungen erfolgreich oder alle Ausführungen schlagen fehl, wodurch die Konsistenz und Integrität der Daten sichergestellt wird. In MySQL können Transaktionen in automatische Übermittlung und manuelle Übermittlung unterteilt werden. Der Unterschied liegt im Zeitpunkt der Transaktionsübermittlung und im Umfang der Kontrolle über die Transaktion. Im Folgenden wird der Unterschied zwischen automatischer Übermittlung und manueller Übermittlung ausführlich vorgestellt und spezifische Codebeispiele zur Veranschaulichung gegeben. 1. Automatisch in MySQL übermitteln, wenn es nicht angezeigt wird

Analyse von Lösungen für Transaktionsmanagementprobleme, die bei der Entwicklung der MongoDB-Technologie auftreten Analyse von Lösungen für Transaktionsmanagementprobleme, die bei der Entwicklung der MongoDB-Technologie auftreten Oct 08, 2023 am 08:15 AM

Analyse von Lösungen für Transaktionsmanagementprobleme, die bei der Entwicklung der MongoDB-Technologie auftreten. Da moderne Anwendungen immer komplexer und umfangreicher werden, werden auch die Anforderungen an die Transaktionsverarbeitung für Daten immer höher. Als beliebte NoSQL-Datenbank verfügt MongoDB über eine hervorragende Leistung und Skalierbarkeit bei der Datenverwaltung. Allerdings weist MongoDB eine relativ schwache Datenkonsistenz und Transaktionsverwaltung auf, was die Entwickler vor Herausforderungen stellt. In diesem Artikel werden wir die bei der MongoDB-Entwicklung auftretenden Transaktionsmanagementprobleme untersuchen und einige Lösungen vorschlagen.

PHP PDO-Tutorial: Ein Leitfaden für Fortgeschrittene von den Grundlagen bis zur Beherrschung PHP PDO-Tutorial: Ein Leitfaden für Fortgeschrittene von den Grundlagen bis zur Beherrschung Feb 19, 2024 pm 06:30 PM

1. Einführung in PDO PDO ist eine Erweiterungsbibliothek von PHP, die eine objektorientierte Möglichkeit zum Betrieb der Datenbank bietet. PDO unterstützt eine Vielzahl von Datenbanken, einschließlich MySQL, Postgresql, Oracle, SQLServer usw. PDO ermöglicht Entwicklern die Verwendung einer einheitlichen API zum Betrieb verschiedener Datenbanken, wodurch Entwickler problemlos zwischen verschiedenen Datenbanken wechseln können. 2. PDO stellt eine Verbindung zur Datenbank her. Um PDO zum Herstellen einer Verbindung zur Datenbank zu verwenden, müssen Sie zunächst ein PDO-Objekt erstellen. Der Konstruktor des PDO-Objekts erhält drei Parameter: Datenbanktyp, Hostname, Datenbankbenutzername und Passwort. Der folgende Code erstellt beispielsweise ein Objekt, das eine Verbindung zu einer MySQL-Datenbank herstellt: $dsn="mysq

Die Prinzipien und Anwendungsszenarien von MySQL-Transaktionen Die Prinzipien und Anwendungsszenarien von MySQL-Transaktionen Mar 02, 2024 am 09:51 AM

Das Prinzip und die Anwendungsszenarien von MySQL-Transaktionen Im Datenbanksystem ist eine Transaktion eine Reihe von SQL-Operationen, die entweder alle erfolgreich ausgeführt werden oder alle fehlschlagen und zurückgesetzt werden. Als häufig verwendetes relationales Datenbankverwaltungssystem unterstützt MySQL Transaktionsmerkmale und kann sicherstellen, dass die Daten in der Datenbank hinsichtlich Konsistenz, Isolation, Haltbarkeit und Atomizität garantiert sind. Dieser Artikel beginnt mit den Grundprinzipien von MySQL-Transaktionen, stellt deren Anwendungsszenarien vor und stellt spezifische Codebeispiele als Referenz für die Leser bereit. Das Prinzip der MySQL-Transaktionen: My

Die branchenweit erste KI-Smart-Screen-Kamera, die Skyworth Smart Screen Camera S50, wird erstmals auf den Markt gebracht Die branchenweit erste KI-Smart-Screen-Kamera, die Skyworth Smart Screen Camera S50, wird erstmals auf den Markt gebracht Nov 18, 2023 pm 06:43 PM

Skyworth Security hat kürzlich sein jährliches Flaggschiff-Neuheitsprodukt herausgebracht – die Skyworth Smart Screen Camera S50. Als erste Smart-Screen-Kamera der Branche, die mit künstlicher Intelligenz ausgestattet ist, besteht das größte Merkmal der Skyworth Smart Screen Camera S50 darin, dass sie einen Farb-Smart-Screen geschickt mit einer Kamera kombiniert, um die innovative Funktion von Zwei-Wege-Videoanrufen zu realisieren Dank der 2T-Rechenleistung wurde die Fähigkeit zur künstlichen Intelligenz erheblich verbessert. Dieses neue Flaggschiff-Produkt des Jahres verfügt über ein futuristisches Erscheinungsbild, fein gefrostetes Material und ist mit einem farbenfrohen, berührbaren hochauflösenden Bildschirm mit reibungsloser und reibungsloser Bedienung ausgestattet Video-Gegensprechanlage, WeChat-Videoanruf; 500 W Extrem klare Bildqualität, 360°-Überwachung ohne tote Winkel; egal wie dunkel es ist, es ist so farbenfroh wie tagsüber; jedes Detail deutlich, wenn Sie hineinzoomen; der umgeschriebene Inhalt ist: 2

Wie verarbeitet die Java-Datenbankverbindung Transaktionen und Parallelität? Wie verarbeitet die Java-Datenbankverbindung Transaktionen und Parallelität? Apr 16, 2024 am 11:42 AM

Transaktionen gewährleisten die Integrität der Datenbankdaten, einschließlich Atomizität, Konsistenz, Isolation und Haltbarkeit. JDBC verwendet die Verbindungsschnittstelle, um die Transaktionssteuerung bereitzustellen (setAutoCommit, Commit, Rollback). Parallelitätskontrollmechanismen koordinieren gleichzeitige Vorgänge mithilfe von Sperren oder optimistischer/pessimistischer Parallelitätskontrolle, um eine Transaktionsisolation zu erreichen und Dateninkonsistenzen zu verhindern.

Beherrschen Sie die Leistungsfähigkeit von PHP PDO: erweiterte Abfragen und Aktualisierungen Beherrschen Sie die Leistungsfähigkeit von PHP PDO: erweiterte Abfragen und Aktualisierungen Feb 20, 2024 am 08:24 AM

Die PHP Data Objects (PDO)-Erweiterung ermöglicht eine effiziente und objektorientierte Interaktion mit Datenbankservern. Seine erweiterten Abfrage- und Aktualisierungsfunktionen ermöglichen es Entwicklern, komplexe Datenbankoperationen durchzuführen und so die Leistung und Wartbarkeit des Codes zu verbessern. Dieser Artikel befasst sich mit den erweiterten Abfrage- und Aktualisierungsfunktionen von PDO und führt Sie durch die Beherrschung seiner leistungsstarken Funktionen. Erweiterte Abfragen: Platzhalter und gebundene Parameter verwenden Platzhalter und gebundene Parameter sind wichtige Werkzeuge zur Verbesserung der Abfrageleistung und -sicherheit. Platzhalter verwenden Fragezeichen (?), um ersetzbare Parameter in der Abfrage darzustellen, während Bind-Parameter es Ihnen ermöglichen, den Datentyp und den Wert jedes Parameters anzugeben. Durch die Verwendung dieser Methoden können Sie SQL-Injection-Angriffe vermeiden und die Leistung verbessern, da die Datenbank-Engine Abfragen im Voraus optimieren kann. //Platzhalter $stmt=$ verwenden

See all articles