Hibernate的多对一操作:

例子参考引用:

http://www.tutorialspoint.com/hibernate/hibernate_many_to_one_mapping.htm

hibernate.cfg.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <session-factory> <!-- Database connection settings -->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://127.0.0.1/testdb</property>
<property name="connection.username">root</property>
<property name="connection.password"></property> <!-- JDBC connection pool (use the built-in) -->
<property name="connection.pool_size">1</property> <!-- SQL dialect -->
<property name="dialect">org.hibernate.dialect.MySQL5Dialect</property> <!-- Enable Hibernate's automatic session context management -->
<property name="current_session_context_class">thread</property> <!-- Disable the second-level cache -->
<property name="cache.provider_class">org.hibernate.cache.internal.NoCacheProvider</property> <!-- Echo all executed SQL to stdout -->
<property name="show_sql">true</property> <!-- Drop and re-create the database schema on startup -->
<property name="hbm2ddl.auto">update</property> <mapping resource="com/my/hbm/User.hbm.xml"/>
<mapping resource="com/my/hbm/UserAccount.hbm.xml"/> </session-factory> </hibernate-configuration>

User.hbm.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping> <class name="com.my.bean.User" table="user">
<id name="id" type="int">
<column name="id" />
<generator class="native" />
</id>
<property name="name" type="java.lang.String" length="50">
<column name="name" not-null="true" length="50" />
</property>
<property name="age" type="int">
<column name="age" />
</property>
<property name="password" type="java.lang.String" length="50">
<column name="password" length="50" />
</property>
<property name="email" type="java.lang.String" length="100">
<column name="email" length="100" />
</property>
<property name="createtime" type="java.util.Date">
<column name="createtime" />
</property>
</class> </hibernate-mapping>

UserAccount.hbm.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping> <class name="com.my.bean.UserAccount" table="user_account">
<id name="id" type="int">
<column name="id" />
<generator class="native" />
</id>
<many-to-one name="user" column="user_id" class="com.my.bean.User" not-null="true"></many-to-one>
<property name="account" type="java.lang.String" length="50">
<column name="account" not-null="true" length="50" />
</property>
</class> </hibernate-mapping>

Java Bean: User.java

package com.my.bean;

import java.util.Date;

public class User {
private int id;
private String name;
private int age;
private String password;
private String email;
private Date createtime; public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public Date getCreatetime() {
return createtime;
}
public void setCreatetime(Date createtime) {
this.createtime = createtime;
}
}

Java Bean: UserAccount.java

package com.my.bean;

public class UserAccount {

    private int id;
private String account;
private User user; public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getAccount() {
return account;
}
public void setAccount(String account) {
this.account = account;
}
public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
} }

HibernateUtil.java

package com.my.dao.util;

import org.hibernate.SessionFactory;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration; public class HibernateUtil { private static final SessionFactory sessionFactory = buildSessionFactory(); private static SessionFactory buildSessionFactory() {
try {
// Create the SessionFactory from hibernate.cfg.xml
Configuration configuration = new Configuration();
return configuration.configure().buildSessionFactory(
new StandardServiceRegistryBuilder().applySettings(configuration.getProperties()).build());
} 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;
} }

测试:

package com.my.init;

import java.util.Date;
import java.util.List; import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session; import com.my.bean.User;
import com.my.bean.UserAccount;
import com.my.dao.util.HibernateUtil; public class Test { public static void main(String[] args) {
Test t = new Test(); // Add new user
User user = t
.addUser("robin", "abcd1234", "robin@88db.com", new Date());
System.out.println(user.getId()); // Get user list
List<User> users = t.listUser();
for (User item : users) {
System.out.println("User name: " + item.getName());
} // Add UserAccount
UserAccount ua = t.addUserAccount("robinzhang", user);
System.out.println("Add UserAccount: " + ua.getId()); // Update UserAccount
UserAccount ua_u = t.updateUserAccount(ua.getId(), "robin_zhang");
System.out.println("Update UserAccount: " + ua_u.getAccount()); // Get User Account List
List<UserAccount> uas = t.listUserAccount();
for (UserAccount item : uas) {
System.out.println("UserAccount: " + item.getAccount());
System.out.println("UserID: " + item.getUser().getId());
} // Delete UserAccount
boolean result = t.deleteUserAccount(1);
System.out.println("Delete UserAccount: " + result); // Delete User
result = t.deleteUser(user);
System.out.println("Delete User: " + result);
} /**
* List Users
*/
@SuppressWarnings("unchecked")
public List<User> listUser() {
Session session = HibernateUtil.getSessionFactory().openSession();
session.beginTransaction(); List<User> users = null;
try {
// Select action
String hqlSelect = "from User where name like :name";
Query query = session.createQuery(hqlSelect);
query.setParameter("name", "%ro%");
users = query.list();
session.getTransaction().commit();
} catch (HibernateException e) {
if (session.getTransaction() != null)
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
}
return users;
} /**
* Add new user
*
* @param name
* User name
* @param password
* User password
* @param email
* User email
* @param createtime
* User create time
* @return User object
*/
public User addUser(String name, String password, String email,
Date createtime) {
Session session = HibernateUtil.getSessionFactory().openSession();
session.beginTransaction(); User u = new User();
try {
u.setName(name);
u.setPassword(password);
u.setCreatetime(createtime);
u.setEmail(email);
u.setAge(18);
// Get new user id
Integer userid = (Integer) session.save(u);
session.getTransaction().commit();
} catch (HibernateException e) {
if (session.getTransaction() != null)
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
} return u;
} /**
* Get UserAccount Object
*
* @param account
* account name
* @param user
* User ID
* @return UserAccount object
*/
public UserAccount addUserAccount(String account, User user) {
Session session = HibernateUtil.getSessionFactory().openSession();
session.beginTransaction(); UserAccount ua = null;
try {
ua = new UserAccount();
ua.setAccount(account);
ua.setUser(user);
session.save(ua);
session.getTransaction().commit();
} catch (HibernateException e) {
if (session.getTransaction() != null)
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
} return ua;
} /**
* Get User Account List
*
* @return
*/
@SuppressWarnings("unchecked")
public List<UserAccount> listUserAccount() {
Session session = HibernateUtil.getSessionFactory().openSession();
session.beginTransaction(); List<UserAccount> uas = null;
try {
String hqlSelect = "from UserAccount where account like :account";
Query query = session.createQuery(hqlSelect);
query.setParameter("account", "%ro%");
uas = query.list();
session.getTransaction().commit();
} catch (HibernateException e) {
if (session.getTransaction() != null)
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
} return uas;
} /**
* Update User Account
*
* @param id
* @param account
*/
public UserAccount updateUserAccount(Integer id, String account) {
Session session = HibernateUtil.getSessionFactory().openSession();
session.beginTransaction(); UserAccount ua = null;
try {
ua = (UserAccount) session.get(UserAccount.class, id);
ua.setAccount(account);
session.update(ua);
session.getTransaction().commit();
} catch (HibernateException e) {
if (session.getTransaction() != null)
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
} return ua;
} /**
* Delete UserAccount
*
* @param id
* @return true/false
*/
public boolean deleteUserAccount(Integer id) {
boolean result = false;
Session session = HibernateUtil.getSessionFactory().openSession();
session.beginTransaction(); try {
UserAccount ua = (UserAccount) session.get(UserAccount.class, id);
session.delete(ua);
session.getTransaction().commit();
result = true;
} catch (HibernateException e) {
if (session.getTransaction() != null)
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
} return result;
} /**
* Delete User
*
* @param user
* @return
*/
public boolean deleteUser(User user) {
boolean result = false;
Session session = HibernateUtil.getSessionFactory().openSession();
session.beginTransaction(); try {
session.delete(user);
session.getTransaction().commit();
result = true;
} catch (HibernateException e) {
if (session.getTransaction() != null)
session.getTransaction().rollback();
e.printStackTrace();
} finally {
session.close();
} return result;
} }

使用Hibernate会自动建库。

[Hibernate] - many to one的更多相关文章

  1. hibernate多对多关联映射

    关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...

  2. 解决 Springboot Unable to build Hibernate SessionFactory @Column命名不起作用

    问题: Springboot启动报错: Caused by: org.springframework.beans.factory.BeanCreationException: Error creati ...

  3. hibernate多对一双向关联

    关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...

  4. Hibernate中事务的隔离级别设置

    Hibernate中事务的隔离级别,如下方法分别为1/2/4/8. 在Hibernate配置文件中设置,设置代码如下

  5. Hibernate中事务声明

    Hibernate中JDBC事务声明,在Hibernate配置文件中加入如下代码,不做声明Hibernate默认就是JDBC事务. 一个JDBC 不能跨越多个数据库. Hibernate中JTA事务声 ...

  6. spring applicationContext.xml和hibernate.cfg.xml设置

    applicationContext.xml配置 <?xml version="1.0" encoding="UTF-8"?> <beans ...

  7. [原创]关于Hibernate中的级联操作以及懒加载

    Hibernate: 级联操作 一.简单的介绍 cascade和inverse (Employee – Department) Casade用来说明当对主对象进行某种操作时是否对其关联的从对象也作类似 ...

  8. hibernate的基本xml文件配置

    需要导入基本的包hibernate下的bin下的required和同bin下optional里的c3p0包下的所有jar文件,当然要导入mysql的驱动包了.下面需要注意的是hibernate的版本就 ...

  9. Maven搭建SpringMVC+Hibernate项目详解 【转】

    前言 今天复习一下SpringMVC+Hibernate的搭建,本来想着将Spring-Security权限控制框架也映入其中的,但是发现内容太多了,Spring-Security的就留在下一篇吧,这 ...

  10. 1.Hibernate简介

    1.框架简介: 定义:基于java语言开发的一套ORM框架: 优点:a.方便开发;           b.大大减少代码量;           c.性能稍高(不能与数据库高手相比,较一般数据库使用者 ...

随机推荐

  1. 《more effective C++》条款10 防止构造函数里的资源泄露

    构造函数也可能发生内存泄露,考虑如下程序: class A { public: A(int *p) { if(p!=NULL) num=p; ); //do something } private: ...

  2. 用python处理数学问题

    一, 计算对数: >>> import math        #导入数学模块>>> math.log(8,2)     #计算以2为底 8的对数3.0>&g ...

  3. 编程工具系列之一------使用GDB的堆栈跟踪功能

    在调试程序的过程中,查看程序的函数调用堆栈是一项最基本的任务,几乎所有的图形调试器都支持这项特性. GDB调试器当然也支持这一特性,但是功能更加灵活和丰富. GDB将当前函数的栈帧编号为0,为外层函数 ...

  4. Notes of Principles of Parallel Programming: Peril-L Notation - TODO

    Content 1 syntax and semantic 2 example set 1 syntax and semantic 1.1 extending C Peril-L notation s ...

  5. jsp不能引用js,cs等解决办法

    最近项目中使用到Spring3,在感叹Spring3注解配置清爽的同时竟然出现了这个不和谐的事情,实在无法忍受 问题:部署项目后程序加载或用浏览器访问时出现类似的警告,2011-01-19 10:52 ...

  6. eBay_GTC和Relist

    1.销售里面有个GTC 那个可以给你做累计销量,如果累计销量高,能大幅提升你的排名位置也可以用30天的摆放方法,修改里面数量,但是30天结束后relist就不知结果了关于累计销量 google搜索里面 ...

  7. P168 实战练习(权限修饰符)

    创建Game类,运行代码如下: package org.hanqi.pn0120; public class Game { private String name; private String ca ...

  8. HDU-1255 覆盖的面积 (扫描线)

    题目大意:给若干个矩形,统计重叠次数不为0的面积. 题目分析:维护扫描线的长度时,只需要只统计覆盖次数大于1的区间即可.这是个区间更新,不过不能使用懒标记,但是数据规模不大,不用懒惰标记仍可以AC. ...

  9. 通过laravel理解IoC(控制反转)容器和DI(依赖注入)

    原文地址: http://www.insp.top/learn-laravel-container ,转载务必保留来源,谢谢了! 容器,字面上理解就是装东西的东西.常见的变量.对象属性等都可以算是容器 ...

  10. 如何更新Android SDK和Build Tool

    1. 运行命令 android 2. 勾选并安装需要的版本 3. 完成!