Maison base de données tutoriel mysql Hibernate基础-HelloWord

Hibernate基础-HelloWord

Jun 07, 2016 pm 04:09 PM
hibernate orm 基础

1. ORM :ORM ( Object / Relation Mapping ): 对象 / 关系映射(理解) 1) ORM 主要解决对象 - 关系的映射 2) .ORM的思想:将关系数据库中表中的记录映射成为对象,以对象的形式展现,程序员可以把对数据库的操作转化为对对象的操作。 2. Hibernate 的 Hel

1. ORM :ORM (Object /Relation Mapping ): 对象/关系映射(理解) 1) ORM 主要解决对象 -关系的映射 2) .ORM的思想:将关系数据库中表中的记录映射成为对象,以对象的形式展现,程序员可以把对数据库的操作转化为对对象的操作。
2. Hibernate 的 HelloWord 1) . 加入 jar 包:加入到当前项目的 classpath 下 hibernate-release-4.2.4.F inal\lib\required\*.jar(所有的包) MySQL 的驱动mysql -connector -java -5.1.29 -bin.jar
2) . 配置 hibernate 的配置文件: hibernate.cfg.xml
①. 利用 hibernate 插件生成 hibernate.cfg.xml

?xml version ="1.0" encoding="UTF-8"?> !DOCTYPE hibernate -configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd "> hibernate-configuration> session -factory > session -factory > hibernate-configuration>
②. 编辑 hibernate.cfg.xml 文件
I. 加入链接数据库的基本信息:
! -- 配置连接数据库的基本信息 --> property name ="connection.driver_class" >com.mysql.jdbc.Driver property > property name ="connection.username" >root property > property name ="connection.password" >123456 property > property name ="connection.url" >jdbc :mysql:///hibernate4property>
II. 配置 Hibernate 使用的数据库方言: 每一种数据库使用的基本语法会有细微的区别,例如分页 MySQL 使用 limit,而 Oracle 使用 rownum。这就需要告诉 Hibernate 底层使用的是哪一种数据库
! -- 配置 Hibernate 的数据库方言 --> property name ="dialect" >org.hibernate.dialect.MySQLInnoDBDialect property > 注意:方言对应的类来自于 hibernate-release- 4.2.4.Final\project\etc\hibernate.properties 中 III. 编辑 Hibernate 的一般属性
! -- 创建数据表的策略(了解,最多使用的值是 update) --> property name ="hbm2ddl.auto" >update property >
> create : 每次运行都会删除上一次的表 ,重新生成表 , 哪怕二次没有任何改变 > create -drop :会根据 .hbm.xml 文件生成表, 但是SessionFactory 一关闭, 表就自动删除 > update :最常用的属性值,也会根据 .hbm.xml 文件生成表 , 但若 .hbm.xml 文件和数据库中对应的数据表的表结构不同 , Hiberante 将更新数据表结构,但不会删除已有的行和列 > validate : 会和数据库中的表进行比较 ,.hbm.xml 文件中的列在数据表中不存在,则抛出异常

! -- 是否打印 SQL --> property name ="show_sql" >trueproperty>
! -- 是否格式化 SQL --> property name ="format_sql" >trueproperty>
3) . 编写实体类( POJO)及 Hibernate 映射文件: xxx.hbm.xml
I. 编写一个 POJO :必须包含一个 OID 字段和数据表主键对应;必须有一个无参数的构造器;为字段定义 getter、 setter;非 final 类
II. 由 hibernate 插件生成 xxx.hbm.xml 文件
注意:需要对文件进行简单的修改:修改主键生成方式(使用 id 的 generator 子节点的 class 属性配置主键的生成方式, native 表示使用数据库本地的方式来 生成主键, MySQL 会自动的选用 auto_increment,而 Oracle 则使用序列的方式)
generator class ="assigned" /> 修改为 generator class="native" />
III. 在 hibernate 配置文件(hiberante.cfg.xml )中关联 hibernate 持久化类的映射文件 mapping resource ="com/atguigu/hibernate/entities/News.hbm.xml" />
4) . 通过 Hibernate API 完成持久化操作
1. 创建 SessionFactory : Session 的工厂类。SessionFactory 是线程安全的,一般地,在一个 Java 应用中只有一个 SessionFactory 实例 Configuration configuration = new Configuration ().configure (); ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings( configuration.getProperties()) .buildServiceRegistry (); SessionFactory sessionFactory = configuration.buildSessionFactory (serviceRegistry );
2. 创建 Session : 表示 Hibernate 应用程序和数据库的一次会话 Session session = sessionFactory.openSession ();
3. 开启事务 Transaction transaction = session.beginTransaction ();
4. 执行持久化操作 //save //session.save (news );
//利用 OID 加载对象 News news2 = (News ) session.get (News.class , 1); System.out.println (news2 ); news2.setContent ("myBatis" );
5. 提交事务 transaction.commit ();
6. 关闭 Session session.close ();
7. 关闭 SessionFactory sessionFactory.close ();

★写测试类的时候一般采用注解更方便些: public class Testing { private SessionFactory sessionFactory ; private Session session ; private Transaction transaction = null ; @Before public void init (){ Configuration configuration = new Configuration ().configure (); ServiceRegistry serviceRegistry = new ServiceRegistryBuilder().applySettings( configuration.getProperties()).buildServiceRegistry(); sessionFactory = configuration.buildSessionFactory (serviceRegistry ); session = sessionFactory.openSession (); transaction = session.beginTransaction (); } @After public void destroy (){ transaction.commit (); session.close (); sessionFactory.close (); } @Test public void test (){ //测试部分 } }

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Framework ORM Tortoise ORM en Python en pratique Framework ORM Tortoise ORM en Python en pratique Jun 10, 2023 pm 06:05 PM

TortoiseORM est un framework ORM asynchrone développé sur la base du langage Python et peut être utilisé pour gérer des bases de données relationnelles dans des applications asynchrones Python. Cet article expliquera comment utiliser le framework TortoiseORM pour créer, lire, mettre à jour et supprimer des données. Vous apprendrez également à effectuer des requêtes simples et complexes à partir d'une base de données relationnelle. Préparation Avant de commencer ce tutoriel, vous devez installer Python (Python3.6+ est recommandé) et installer TortoiseOR.

Comment utiliser le mappage objet-relationnel (ORM) en PHP pour simplifier les opérations de base de données ? Comment utiliser le mappage objet-relationnel (ORM) en PHP pour simplifier les opérations de base de données ? May 07, 2024 am 08:39 AM

Les opérations de base de données en PHP sont simplifiées à l'aide d'ORM, qui mappe les objets dans des bases de données relationnelles. EloquentORM dans Laravel vous permet d'interagir avec la base de données en utilisant une syntaxe orientée objet. Vous pouvez utiliser ORM en définissant des classes de modèle, en utilisant des méthodes Eloquent ou en créant un système de blog dans la pratique.

Comment Hibernate implémente-t-il le mappage polymorphe ? Comment Hibernate implémente-t-il le mappage polymorphe ? Apr 17, 2024 pm 12:09 PM

Le mappage polymorphe Hibernate peut mapper les classes héritées à la base de données et fournit les types de mappage suivants : join-subclass : crée une table séparée pour la sous-classe, incluant toutes les colonnes de la classe parent. table par classe : créez une table distincte pour les sous-classes, contenant uniquement des colonnes spécifiques aux sous-classes. union-subclass : similaire à join-subclass, mais la table de classe parent réunit toutes les colonnes de la sous-classe.

Quel est le mécanisme ORM du framework Java Hibernate ? Quel est le mécanisme ORM du framework Java Hibernate ? Apr 17, 2024 pm 02:39 PM

Hibernate est un framework JavaORM pour le mappage entre les objets Java et les bases de données relationnelles. Son mécanisme ORM comprend les étapes suivantes : Annotation/Configuration : La classe d'objets est marquée avec des annotations ou des fichiers XML, spécifiant ses tables et colonnes de base de données mappées. Fabrique de sessions : gère la connexion entre Hibernate et la base de données. Session : représente une connexion active à la base de données et est utilisée pour effectuer des opérations de requête et de mise à jour. Persistance : enregistrez les données dans la base de données via la méthode save() ou update(). Requête : utilisez les critères et HQL pour définir des requêtes complexes afin de récupérer des données.

Tutoriel de base de PHP : du débutant au maître Tutoriel de base de PHP : du débutant au maître Jun 18, 2023 am 09:43 AM

PHP est un langage de script open source côté serveur largement utilisé qui peut gérer toutes les tâches de développement Web. PHP est largement utilisé dans le développement Web, notamment pour ses excellentes performances en matière de traitement dynamique des données, il est donc apprécié et utilisé par de nombreux développeurs. Dans cet article, nous expliquerons les bases de PHP étape par étape pour aider les débutants à devenir compétents. 1. Syntaxe de base PHP est un langage interprété dont le code est similaire au HTML, CSS et JavaScript. Chaque instruction PHP se termine par un point-virgule ;

Quels sont les inconvénients du framework Hibernate ORM ? Quels sont les inconvénients du framework Hibernate ORM ? Apr 18, 2024 am 08:30 AM

Le framework HibernateORM présente les inconvénients suivants : 1. Consommation de mémoire importante car il met en cache les résultats des requêtes et les objets d'entité. 2. Une complexité élevée, nécessitant une compréhension approfondie de l'architecture et de la configuration. 3. Des délais de chargement retardés, entraînant des retards inattendus ; . Des goulots d'étranglement en matière de performances peuvent survenir lorsqu'un grand nombre d'entités sont chargées ou mises à jour en même temps. 5. Implémentation spécifique au fournisseur, entraînant des différences entre les bases de données.

Comment le mappage objet-relationnel PHP et les couches d'abstraction de base de données améliorent la lisibilité du code Comment le mappage objet-relationnel PHP et les couches d'abstraction de base de données améliorent la lisibilité du code May 06, 2024 pm 06:06 PM

Réponse : ORM (Object Relational Mapping) et DAL (Database Abstraction Layer) améliorent la lisibilité du code en faisant abstraction des détails d'implémentation de la base de données sous-jacente. Description détaillée : ORM utilise une approche orientée objet pour interagir avec la base de données, rapprochant le code de la logique de l'application. DAL fournit une interface commune indépendante des fournisseurs de bases de données, simplifiant ainsi l'interaction avec différentes bases de données. L'utilisation d'ORM et de DAL peut réduire l'utilisation d'instructions SQL et rendre le code plus concis. Dans des cas pratiques, ORM et DAL peuvent simplifier la requête d'informations sur le produit et améliorer la lisibilité du code.

Bases du mappage relationnel objet (ORM) : comprendre la doctrine ORM Bases du mappage relationnel objet (ORM) : comprendre la doctrine ORM Jun 19, 2023 pm 03:43 PM

Principes de base du mappage objet-relationnel (ORM) : Comprendre DoctrineORM Lorsque nous développons des applications, nous devons opérer sur la base de données pour stocker et récupérer des données. Cependant, il n'est pas pratique d'utiliser directement le code de requête de base de données d'origine. Nous devons établir une relation de cartographie entre les objets et les données. C'est le rôle de l'ORM. ORM mappe et convertit automatiquement les objets et les tables de base de données, permettant une manipulation facile des données, rendant notre code plus facile à maintenir. DoctrineORM est PHP

See all articles