hibernate用注解连接mysql,利用Hibernate Tools生成与数据库表对应的带注解实体类

主要分三个阶段。1.连接数据源;2.创建Hibernate配置文件;3.生成实体类。

一、连接数据源

1.在Eclipse的菜单栏,选择"Window"->"Show View"->"Other"->"Date Source Exploer"-"OK",将会显示一个名为"Date Source Exploer";

2.在"Date Source Exploer"右击“Database Connection"->"New",弹出一个窗口,选择需要的数据库;

3.接着新建一个数据库驱动的配置。(1)选择数据库驱动类型(2)选择数据库驱动包的放置路径(3)填写连接地址、账户、密码等连接数据库所需用到的基本信息。

4.填写完后,会列出你先前填的信息。接着点击"Test Connection",测试能否成功连接上数据库。确认无误,便可点击"Finish"。“Database Connection"将会显示 数据库中的表。第一阶段完成。

二、创建Hibernate配置文件

1.在Eclipse的菜单栏,选择"Window"->"Show View"->"Other"->"Hibernate Configurations"-"OK",将会显示一个名为"Hibernate Configurations"窗口;

2.在"Hibernate Configurations"窗口内右击,选择"Add Configuration",弹出"Edit Configuration"窗口;

3.在"Main"的tabpanel,填入需要导进的项目,选择Annotation(jdk5.0+)单选圆框,选择第一阶段创建“Data Source”,接着创建hibernate.properties或hibernate.cfg.xml(强烈建议使用这个),二选一。若选创建hibernate.cfg.xml,接着并要求填写相关连接数据库需要用到的连接URL、账户、密码、方言等。

4.在"Option"的tabpanel中选择对应的方言。

5.在"Common"的tabpanel中选择UTF-8字符集。

6.点击"OK",在"Hibernate Configurations"窗口会显示先前配置项。第二阶段完成。

三、生成实体

1.在工具栏中,点击带Hibernate Logo 的"Run as"旁的三角,再点击"Hibernate Code Geneartion Configurations",弹出窗口;

652976fad871d1e9f4f556cff5af07f6.png

2.右击"Hibernate Code Geneartion"->"New";

3.在窗口右侧的"Main" tabpanel中,"Console Configuration"填写第二阶段创建的Hibernate配置,填写实体类放置的文件夹位置,点击"Reverse engineer from JDBC Connection”,"Package"位置变得可填(如果不填的话,生成的实体都是默认包,也就是说,实体.java的头一行没有"package *;"这一句。如果填了,放置位置会重新命名,还要加多一步手动地重命名包名。最后还是选择后者,也就是选择填);

3.1(选择)reveng.xml的作用,我理解为更加细粒度地选择表导出,选择不填的的话,全部表都导出。

4.完成第3步后,点击"Exporters"的tabpanel,点击复选"Use Java 5 Syntax","Grnerate EJB3 annotaion",然后点击下方的“Domain code(.java)”的复选, 方可点击"Run";

5."让子弹飞一会儿---",接着在你指定的包看到工具生成实体类。第三阶段完成。

PS:

1.在第三阶段的第4步,遇到“reading schema error: null”异常,解决方法是在hibernate.cfg.xml的->添加

2.附上HibernateUtil(Hibernate3与Hibernate4的有所不同,应该与Hibernate4的策略有关)

public class HibernateUtil {

private static final SessionFactory sessionFactory = buildSessionFactory();

private static SessionFactory buildSessionFactory() {

try {

Configuration cfg = new Configuration().configure();

StandardServiceRegistry serviceRegistry = new StandardServiceRegistryBuilder()

.applySettings(cfg.getProperties()).build();

// Create the SessionFactory from hibernate.cfg.xml

return cfg.buildSessionFactory(serviceRegistry);

}

catch (Throwable ex) {

// Make sure you log the exception, as it might be swallowed

System.err.println("Initial SessionFactory creation failed." + ex);

throw new ExceptionInInitializerError(ex);

}

}

public static SessionFactory getSessionFactory() {

return sessionFactory;

}

}

3.操作基本的CRUD的方法模板

@Test

public void doData(){

Session session = HibernateUtil.getSessionFactory().openSession();

session.beginTransaction();

try{

//相关数据库操作

//session.saveOrUpdate(m);

session.getTransaction().commit();

}catch(Exception e){

session.getTransaction().rollback();

e.printStackTrace();

}finally{

if(session != null)

session.close();

}

}

参考文献

1.eclipse从数据库逆向生成Hibernate实体类-http://blog.csdn.net/wangpeng047/article/details/6877720

2.Eclipse从数据库逆向生成Hibernate带注解的实体类-http://www.2cto.com/database/201501/372023.html

3.reading schema error: null,readingschema-http://www.bkjia.com/sjkqy/995143.html

4.hibernate4.3.4.final出现的一个问题-http://bbs.csdn.net/topics/390746425

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值