- 浏览: 78714 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
zhuzf:
我也出现这样的问题,但我的问题是:查询的语句中的字段与实体中的 ...
java.sql.SQLException: ORA-01722: 无效数字
进入:http://www.hibernate.org 说明文档: 英文:http://docs.jboss.org/hibernate/annotations/3.5/reference/en/html_single/ 中文:http://docs.jboss.org/hibernate/annotations/3.4/reference/zh_cn/html_single/ 下载:hibernate annotation 3.4.0 GA 得到:hibernate-annotations.jar hibernate-commons-annotation.jar ejb3-persistence.jar 数据库:mysql category表:id,name,description <Pk>id product表:id,name ,price, description ,category_id <pk>id <fk>category_id 新建java project项目: Add Hibernate Capabilities 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"> <!-- Generated by MyEclipse Hibernate Tools. --> <hibernate-configuration> <session-factory> <property name="dialect"> org.hibernate.dialect.MySQLDialect </property> <property name="connection.url"> jdbc:mysql://localhost:3307/users </property> <property name="connection.username">root</property> <property name="connection.password">root</property> <property name="connection.driver_class"> com.mysql.jdbc.Driver </property> <property name="myeclipse.connection.profile"> mysqlusers </property> <property name="format_sql">true</property> <property name="show_sql">true</property> <property name="current_session_context_class">thread</property> <mapping class="com.b510.examples.Product" /> <mapping class="com.b510.examples.Category" /> </session-factory> </hibernate-configuration> 利用Hibernate的逆向工程生成: Category.java and Product.java Category.java package com.b510.examples; import java.util.HashSet; import java.util.Set; // 标准注解 import javax.persistence.CascadeType; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.FetchType; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.OneToMany; import javax.persistence.Table; //增加的注解 import org.hibernate.annotations.GenericGenerator; //当前的类是一个持久化类,是Category这个类。他映射了一个表category。所对应的 数据库是users //这句:@Table(name = "category", catalog = "users") 可以省略 @Entity @Table(name = "category", catalog = "users") public class Category implements java.io.Serializable { private static final long serialVersionUID = 3240281547213597385L; private Integer id; private String name; private String description; private Set<Product> products = new HashSet<Product>(0); public Category() { } public Category(String name, String description, Set<Product> products) { this.name = name; this.description = description; this.products = products; } // 主键 :@Id 主键生成方式:strategy = "increment" //映射表中id这个字段,不能为空,并且是唯一的 @GenericGenerator(name = "generator", strategy = "increment") @Id @GeneratedValue(generator = "generator") @Column(name = "id", unique = true, nullable = false) public Integer getId() { return this.id; } public void setId(Integer id) { this.id = id; } //映射表中name这个字段 ,长度是500 @Column(name = "name", length = 500) public String getName() { return this.name; } public void setName(String name) { this.name = name; } //映射表中description这个字段 ,长度是500 @Column(name = "description", length = 500) public String getDescription() { return this.description; } public void setDescription(String description) { this.description = description; } //级联操作:cascade = CascadeType.ALL //延迟加载:fetch = FetchType.LAZY //映射:mappedBy = "category" //一对多方式 @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "category") public Set<Product> getProducts() { return this.products; } public void setProducts(Set<Product> products) { this.products = products; } } Product.java 代码: package com.b510.examples; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.FetchType; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.ManyToOne; import javax.persistence.Table; import org.hibernate.annotations.GenericGenerator; @Entity @Table(name = "product", catalog = "users") public class Product implements java.io.Serializable { private static final long serialVersionUID = -1546206493725028472L; private Integer id; private Category category; private String name; private String price; private String descripton; public Product() { } public Product(Category category, String name, String price, String descripton) { this.category = category; this.name = name; this.price = price; this.descripton = descripton; } @GenericGenerator(name = "generator", strategy = "increment") @Id @GeneratedValue(generator = "generator") @Column(name = "id", unique = true, nullable = false) public Integer getId() { return this.id; } public void setId(Integer id) { this.id = id; } //延迟加载:多对一方式 //关联信息:外键name = "category_id" @ManyToOne(fetch = FetchType.LAZY) @JoinColumn(name = "category_id") public Category getCategory() { return this.category; } public void setCategory(Category category) { this.category = category; } @Column(name = "name", length = 500) public String getName() { return this.name; } public void setName(String name) { this.name = name; } @Column(name = "price", length = 10) public String getPrice() { return this.price; } public void setPrice(String price) { this.price = price; } @Column(name = "descripton", length = 500) public String getDescripton() { return this.descripton; } public void setDescripton(String descripton) { this.descripton = descripton; } } 测试代码: HibernateTest.java 代码: /** * */ package com.b510.examples; import java.util.Set; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.cfg.AnnotationConfiguration; import org.hibernate.cfg.Configuration; /** * * @author XHW * * @date 2011-7-20 * */ public class HibernateTest { public static void main(String[] args) { HibernateTest test=new HibernateTest(); test.add(); test.find(); } public void add(){ Configuration config=new AnnotationConfiguration(); config.configure(); SessionFactory sessionFactory=config.buildSessionFactory(); Session session=sessionFactory.getCurrentSession(); session.beginTransaction(); Category c=(Category)session.get(Category.class, 5); Product p=new Product(); p.setName("计算机科学与技术"); p.setPrice("123"); p.setDescripton("计算机科学与技术,好啊,真是红啊"); p.setCategory(c); c.getProducts().add(p); session.save(p); session.getTransaction().commit(); } public void find(){ Configuration config=new AnnotationConfiguration(); config.configure(); SessionFactory sessionFactory=config.buildSessionFactory(); Session session=sessionFactory.getCurrentSession(); session.beginTransaction(); Category c=(Category)session.get(Category.class, 5); System.out.println("id: "+c.getId()+" name:"+c.getName()); Set<Product> p=c.getProducts(); for(Product product:p){ System.out.println("id:"+product.getId()+" name:"+product.getName()+" description:"+product.getDescripton()); } session.getTransaction().commit(); } } 运行效果: log4j:WARN No appenders could be found for logger (org.hibernate.cfg.annotations.Version). log4j:WARN Please initialize the log4j system properly. Hibernate: select category0_.id as id1_0_, category0_.description as descript2_1_0_, category0_.name as name1_0_ from users.category category0_ where category0_.id=? Hibernate: select products0_.category_id as category5_1_, products0_.id as id1_, products0_.id as id0_0_, products0_.category_id as category5_0_0_, products0_.descripton as descripton0_0_, products0_.name as name0_0_, products0_.price as price0_0_ from users.product products0_ where products0_.category_id=? Hibernate: select max(id) from product Hibernate: insert into users.product (category_id, descripton, name, price, id) values (?, ?, ?, ?, ?) Hibernate: select category0_.id as id5_0_, category0_.description as descript2_5_0_, category0_.name as name5_0_ from users.category category0_ where category0_.id=? id: 5 name:xml33 Hibernate: select products0_.category_id as category5_1_, products0_.id as id1_, products0_.id as id4_0_, products0_.category_id as category5_4_0_, products0_.descripton as descripton4_0_, products0_.name as name4_0_, products0_.price as price4_0_ from users.product products0_ where products0_.category_id=? id:9 name:计算机科学与技术 description:计算机科学与技术,好啊,真是红啊
发表评论
-
Hibernate中execute、executeQuery和executeUpdate之间的区别
2012-05-03 18:23 1022Statement 接口提供了三种执行 SQL 语句的方法:e ... -
java.sql.SQLException: ORA-01722: 无效数字
2011-12-15 13:58 12904[eStore]2011-12-15 13:47:21,890 ... -
org.springframework.orm.hibernate3.HibernateObjectRetrievalFailureException
2011-11-24 16:15 1850org.springframework.orm.hiberna ... -
hibernate中SQLQuery
2011-11-21 17:46 1179对原生SQL查询执行的控制是通过S ...
相关推荐
本文档将深入探讨Hibernate注解的使用,帮助开发者更好地理解和利用这些注解来实现对象关系映射(ORM)。 一、Hibernate注解基础 Hibernate注解是一种元数据方式,用于在Java类和属性上声明数据库映射信息,从而...
使用hibernate注解,必须要使用库hibernate-commons-annotations,hibernate-core,hibernate-jpa,ejb3-persistence,javassist等
本主题将深入探讨Hibernate注解的相关知识点。 1. **注解概述**: 注解(Annotations)是Java 5引入的一种元数据,它提供了在源代码中嵌入信息的方式,这些信息可以被编译器或者在运行时的Java虚拟机使用。在...
这个"springmvc+hibernate注解框架整合 demo"是一个示例项目,展示了如何通过注解方式将这两个框架无缝集成。 **Spring MVC 框架** Spring MVC 是 Spring 框架的一部分,它提供了处理HTTP请求、转发响应以及管理...
### Hibernate注解API知识点概述 #### 一、Hibernate注解简介 Hibernate 是一款非常流行的 Java 持久层框架,它极大地简化了数据库操作。在 Hibernate 中,可以通过使用注解来映射对象与数据库表之间的关系,从而...
在实际项目中,除了这三个核心的Hibernate注解库,可能还需要其他的依赖,例如: - **jta.jar**:Java Transaction API,用于支持分布式事务处理。 - **javax.persistence-api.jar**:JPA规范的API,包含了一些基础...
《Hibernate注解详解》 Hibernate 是一款强大的Java对象关系映射(ORM)框架,它极大地简化了数据库操作。在Hibernate中,注解是用于描述Java类及其属性如何映射到数据库表的重要工具。本文将全面解析Hibernate中的...
总的来说,Hibernate注解使得Java对象与数据库表之间的映射变得更加直观和简洁,极大地减少了代码量,提高了开发效率。通过熟练掌握这些注解,开发者可以更好地利用Hibernate框架进行数据库操作。
"Hibernate注解一对多,多对一"是两个常见的关系映射类型,适用于处理实体类之间的复杂关联。 一、一对多关系 在现实世界中,例如一个部门有多个员工,这就是一对多的关系。在Hibernate中,我们可以使用`@...
### Hibernate注解详解 #### 一、概述 Hibernate是一个开源的对象关系映射(ORM)框架,用于Java应用程序中实现数据库操作。它通过提供强大的映射工具和服务,简化了基于Java的应用程序开发人员对数据库的访问过程...
【hibernate注解详解】 Hibernate 是一个流行的Java ORM(对象关系映射)框架,它允许开发者使用面向对象的方式操作数据库。在Hibernate中,注解是声明对象与数据库表之间映射关系的主要方式。以下是对描述中提到的...
本实例"spring-hibernate注解配置源码"旨在展示如何在不使用XML配置的情况下,通过注解的方式整合Struts2、Spring和Hibernate,创建一个完整的MVC(模型-视图-控制器)架构的应用。下面将详细介绍这个过程中的关键...
下面我们将详细讲解如何配置和使用Spring+Hibernate注解声明式事务: 1. **配置Spring**: - 首先,我们需要在Spring配置文件中启用事务管理器,通常是`HibernateTransactionManager`,并配置数据源。 - 然后,...
在Java的ORM框架Hibernate中,注解是一种强大的工具,它允许开发者无需XML配置就能实现对象关系映射。本文主要总结了Hibernate中常见的注解用法,涵盖了类级别和属性级别的注解,以及与主键和非主键相关的注解。 1....
《Hibernate注解详解》 在Java开发领域,Hibernate作为一个强大的对象关系映射(ORM)框架,极大地简化了数据库操作。而随着Java注解的普及,Hibernate也开始广泛采用注解方式来替代XML配置,使得代码更加简洁,...
然后,在实体类中使用Hibernate注解定义数据模型,如: ```java import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence...
### Hibernate注解配置详解 #### 一、概述 Hibernate 是一款强大的对象关系映射(ORM)框架,它简化了Java应用程序与数据库之间的交互过程。在使用Hibernate的过程中,开发者可以通过注解来实现对象与数据库表之间...
在 Hibernate 中,注解是一种简洁且强大的工具,用于替代传统的 XML 配置文件来描述对象模型和数据库之间的映射关系。这篇文档将深入探讨 Hibernate 注解的使用。 ### 第 1 章 创建一个注解项目 在开始使用 ...
### Hibernate注解编程实例 #### Hibernate注解简介 在Java领域中,Hibernate作为一个非常流行的ORM(Object Relational Mapping,对象关系映射)框架,极大地简化了数据库操作的复杂度。通过将Java对象与数据库表...