[原创]java WEB学习笔记77:Hibernate学习之路---Hibernate 版本 helloword,

本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用

内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系。

本人互联网技术爱好者,互联网技术发烧友

微博:伊直都在0221

QQ:951226918

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

用的是 hibernate-release-4.2.4.Final 版本学习

1.准备Hibernate 开发环境

  1)导入 Hibernate 必须的 jar 包:

    

  2)加入数据库驱动的 jar 包:

    

2.开发步骤

    1). 创建 Hibernate 配置文件

  hibernate.cfg.xml  必须在src 的根目录下    

 1 <?xml version="1.0" encoding="UTF-8"?>
 2 <!DOCTYPE hibernate-configuration PUBLIC
 3         "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
 4         "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
 5 <hibernate-configuration>
 6     <session-factory>
 7         <!-- 李恩家数据库的基本信息 -->
 8         <property name="connection.username">root</property>
 9         <property name="connection.password">zhangzhen</property>
10         <property name="connection.driver_class">com.mysql.jdbc.Driver</property>
11         <property name="connection.url">jdbc:mysql:///hibernate</property>
12
13
14         <!-- 配置hibernate 的节本信息 -->
15         <!-- hibernate 所使用的数据库方言 -->
16      <!--     <property name="dialect">org.hibernate.dialect.MySQLInnoDBDialect</property>-->
17
18
19   <property name="dialect">org.hibernate.dialect.MySQLDialect</property>
20         <!-- 执行操作时是否在控制台打印SQL  -->
21         <property name="show_sql">true</property>
22
23         <!-- 是否都SQL 进行格式化 -->
24         <property name="format_sql">true</property>
25
26
27         <!-- 指定自动生成数据表的策略 -->
28         <property name="hbm2ddl.auto">update</property>
29
30
31         <!-- 指定关联的 .hbm.xml 文件 -->
32         <mapping resource="hibernate/helloworld/News.hbm.xml"/>
33
34     </session-factory>
35
36 </hibernate-configuration>

  2). 创建持久化类

News.java

 1 package hibernate.helloworld;
 2
 3 import java.sql.Date;
 4
 5 public class News {
 6
 7     private Integer id;
 8     private String title;
 9     private String author;
10
11     private Date date;
12
13     public Integer getId() {
14         return id;
15     }
16
17     public void setId(Integer id) {
18         this.id = id;
19     }
20
21     public String getTitle() {
22         return title;
23     }
24
25     public void setTitle(String title) {
26         this.title = title;
27     }
28
29     public String getAuthor() {
30         return author;
31     }
32
33     public void setAuthor(String author) {
34         this.author = author;
35     }
36
37     public Date getDate() {
38         return date;
39     }
40
41     public void setDate(Date date) {
42         this.date = date;
43     }
44
45     public News() {
46
47     }
48
49     public News(String title, String author, Date date) {
50         super();
51         this.title = title;
52         this.author = author;
53         this.date = date;
54     }
55
56     @Override
57     public String toString() {
58         return "News [id=" + id + ", title=" + title + ", author=" + author
59                 + ", date=" + date + "]";
60     }
61
62
63
64
65 }

  3). 创建对象-关系映射文件

News.hbm.xml

 1 <?xml version="1.0"?>
 2 <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
 3 "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
 4 <!-- Generated 2016-10-3 16:36:59 by Hibernate Tools 3.4.0.CR1 -->
 5 <hibernate-mapping>
 6     <class name="hibernate.helloworld.News" table="NEWS">
 7
 8         <id name="id" type="java.lang.Integer">
 9             <column name="ID" />
10             <!-- 指定主键的生成方式:native:使用数据库本地方式 -->
11             <generator class="native" />
12         </id>
13
14         <property name="title" type="java.lang.String">
15             <column name="TITLE" />
16         </property>
17
18         <property name="author" type="java.lang.String">
19             <column name="AUTHOR" />
20         </property>
21
22         <property name="date" type="java.sql.Date">
23             <column name="DATE" />
24         </property>
25
26     </class>
27 </hibernate-mapping>

  4). 通过 Hibernate API 编写访问数据库的代码

HibernateTest.java

 1 package hibernate.helloworld;
 2
 3 import static org.junit.Assert.*;
 4
 5 import java.sql.Date;
 6
 7 import org.hibernate.Session;
 8 import org.hibernate.SessionFactory;
 9 import org.hibernate.Transaction;
10 import org.hibernate.cfg.Configuration;
11 import org.hibernate.service.ServiceRegistry;
12 import org.hibernate.service.ServiceRegistryBuilder;
13 import org.junit.Test;
14
15 public class HibernateTest {
16
17     @Test
18     public void test() {
19
20         //1. 创建一个SessionFatory 对象
21         SessionFactory sessionFactory =  null;
22
23             //1) 创建Configuration 对象:对应hibernate 的基本配置信息 和 对象关系映射信息
24                 Configuration configuration = new Configuration().configure();
25
26             //2) 创建一个ServiceRegistry 对象:hibernate 4.x 新天添加的对象。
27             //hibernate 的任何配置 和 服务都需要在该对象中注册后才有效
28                 ServiceRegistry  serviceRegistry = new ServiceRegistryBuilder().applySettings(configuration.getProperties())
29                                                                                .buildServiceRegistry();
30
31             //    sessionFactory = configuration.buildSessionFactory();
32                 sessionFactory = configuration.buildSessionFactory(serviceRegistry);
33
34         //2. 创建一个session 对象
35                 Session session = sessionFactory.openSession();
36
37         //3. 开启事物
38             Transaction transaction = session.beginTransaction();
39
40         //4.执行保存操作
41             News news = new News("java","jason",new Date(new java.util.Date().getTime()));
42             session.save(news);
43
44         //5.提交事物
45             transaction.commit();
46         //6.关闭session
47             session.close();
48         //7.关闭SessionFactory 对象
49             sessionFactory.close();
50     }
51
52 }

预期结果:在对应的数据库中生成指定的数据表,并且插入指定的数据

     

注意:

  我在学习过程中第一次将数据库的方言设置为

<property name="dialect">org.hibernate.dialect.MySQLInnoDBDialect</property>

执行的时候 出现了错误:Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table ‘hibernate.news‘ doesn‘t exist

之后参考了百度,stackoverflow,csdn,谷歌,改了数据库连接jar包。。。。。都没起作用

最后在一篇博客中找到来解决方案:

[转]Hibernate不能自动建表解决办法及Hibernate不同数据库的连接及SQL方言

时间: 2024-10-20 18:05:16

[原创]java WEB学习笔记77:Hibernate学习之路---Hibernate 版本 helloword,的相关文章

[原创]java WEB学习笔记95:Hibernate 目录

本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 -----------------------------------------------------------------------------------------------------------------

[原创]java WEB学习笔记6:Struts2 学习之路--Struts的CRUD操作( 查看 / 删除/ 添加) 使用 paramsPrepareParamsStack 重构代码 ,PrepareInterceptor拦截器,paramsPrepareParamsStack 拦截器栈

本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 -----------------------------------------------------------------------------------------------------------------

[原创]java WEB学习笔记75:Struts2 学习之路-- 总结 和 目录

本博客的目的:①总结自己的学习过程,相当于学习笔记 ②将自己的经验分享给大家,相互学习,互相交流,不可商用 内容难免出现问题,欢迎指正,交流,探讨,可以留言,也可以通过以下方式联系. 本人互联网技术爱好者,互联网技术发烧友 微博:伊直都在0221 QQ:951226918 -----------------------------------------------------------------------------------------------------------------

【web开发学习笔记】Struts-Tags学习笔记1 - 通用标签和控制标签

通用标签和控制标签 第一部分:代码 //前端 <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=GB18030" /> <title>Insert title here</title> </head> <body> 访问属性 <a href="<%=contextP

【web开发学习笔记】ibatis学习总结

ibatis学习总结 ibatis数据库配置文件 <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE sqlMapConfig PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN" "http://ibatis.apache.org/dtd/sql-map-config-2.dtd"> <

[学习笔记] Sencha Cmd 学习笔记 Sencha Cmd是什么

本文地址: http://blog.csdn.net/sushengmiyan/article/details/38295575 本文作者:sushengmiyan -------------------------------------------------------------资源链接----------------------------------------------------------------------- 翻译来源  Sencha Cmd官方网站: http://w

Accelerated C++学习笔记1—&lt;开始学习C++&gt;

第0章 开始学习C++ 1.每次学习一个新的语言,大家都是从Hello, world!开始 // lesson0_1.cpp : 定义控制台应用程序的入口点. //功能:编译并运行Hello,world //时间:2014.5.7 #include "stdafx.h" #include "iostream" using namespace std; int _tmain(int argc, _TCHAR* argv[]) { std::cout<< &

[Linux] 学习笔记之安装学习环境(sshd, lrzsz)

紧接前一篇,在VMWare安装完Linux,这个时候我们要使用远程工具连接到虚拟机上去了,以前一直使用Putty,后来到新公司之后,推荐使用SecureCRT,使用之后,觉得效果不错,但是每次连接都失败,linux新手伤不起,在网上搜啊搜,终于找到解决办法.   搜索了很多资料之后,发现是由于我未在Linux上安装ssh服务导致无法使用SecureCRT连接. 1. 可以使用ssh localhost对此进行测试,具体使用如下: 2. 使用apt-get或者yum安装ssh服务,具体哪种操作系统

iOS学习笔记---c语言学习第七天

结构体 结构体是一种自定义的数据类型 struct 结构体名 { 类型说明符  成员名: … 类型说明符  成员名: }: #import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { struct teacher{ char name[30]; char sex; int age; char course[30]; }; typedef struct teacher Teacher; Teacher c

树莓派学习笔记——GPIO功能学习

树莓派学习笔记——GPIO功能学习