hibernate实体类| 耗时:0.148秒|35011条结果

Hibernate实体类的操作

(); u.setUid(1); session.delete(u); saveOrUpdate()方法的使用 此方法根据实体类的状态选择添加或修改 //1. 瞬时态,添加 User uu = new User(); uu.setUsername("jack"
http://www.itnose.net/detail/6721337.html 2017-02-19 17:15   [Hibernate]

Hibernate注解-实体类注解

@Entity @Table(name = "EMP", schema = "SCOTT") public class Emp implements java.io.Serializable { // Fields private Short empno; private Dept dept; private String ename; private String job; private Short mgr; private Date hiredate; private Double sal; private Double comm; // Constructors /** default constructor */ public Emp() { } /** full constructor */ public Emp(Dept dept, String ename, String job, Short mgr, Date hiredate, Double sal, Double comm) { this.dept = dept; this.ename = ename; this.job = job; this.mgr = mgr; this.hiredate = hiredate; this.sal = sal; this.comm = comm; } // Property accessors @Id @GeneratedValue @Column(name = "EMPNO", unique = true, nullable = false, precision = 4, scale = 0) public Short getEmpno() { return this.empno; } public void setEmpno(Short empno) { this.empno = empno; } @ManyToOne(fetch = FetchType.LAZY) @JoinColumn(name = "DEPTNO") public Dept getDept() { return this.dept; } public void setDept(Dept dept) { this.dept = dept; } @Column(name = "ENAME", length = 10) public String getEname() { return this.ename; } public void setEname(String ename) { this.ename = ename; } @Column(name = "JOB", length = 9) public String getJob() { return this.job; } public void setJob(String job) { this.job = job; } @Column(name = "MGR", precision = 4, scale = 0) public Short getMgr() { return this.mgr; } public void setMgr(Short mgr) { this.mgr = mgr; } @Temporal(TemporalType.DATE) @Column(name = "HIREDATE", length = 7) public Date getHiredate() { return this.hiredate; } public void setHiredate(Date hiredate) { this.hiredate = hiredate; } @Column(name = "SAL", precision = 7) public Double getSal() { return this.sal; } public void setSal(Double sal) { this.sal = sal; } @Column(name = "COMM", precision = 7) public Double getComm() { return this.comm; } public void setComm(Double comm) { this.comm = comm; } } 上方的2个注解 @Entity标志这个实体 @Table中name属性值为数据库表名, schema属性值就是数据库用户名,默认为"",可以不写,一般来说,写这2个属性就够了.其他不介绍. 属性注解最好写在get方法上方: 1.@id表示这个是OID属性,对应着数据库的主键,注意OID必须为long,int或者short. 2.@GenerateValue 中有2个属性,strategy表示主键生成策略,默认值为StrategyType.AUTO(另外3个值为:IDENTITY,SEQUENCE,TABLE) 其中AUTO表示hibernate自动选择 IDENTITY表示根据底层数据库生成,支持mysql,db2,sqlserver,sybase等数据库 SEQUENCE也由底层数据库生成,支持oracle,db2,postgresql TABLE表示根据另外的表生成 3.@Column可以配置实体属性与数据库表字段的对应关系 name属性值为表字段名 unique 是否唯一 nullable 是否可以为null precision 有效位数 scale  小数位数 length 数据长度 insertable 该字段是否可以插入到
http://www.itnose.net/detail/6402280.html 2015-11-06 04:50   [Hibernate]

关于hibernate一个实体类对应多个表的问题

老师的项目要求用hibernate来管理数据库,但是数据库中一共有600多张表,让我一个一个的建立表所对应的实体类有些不太现实,但是我初学hibernate,没能找到好的方法。 在hibernate3中,我想要建立这样的一个实体类,在不同的情况下可以对应不同的表,不知道这样可行不?如果可行,请教我如何操作,如果实现不了的话,请告诉我有什么好的方法可以避免建立600多个实体类才能实现查询。谢谢。 回复讨论(解决方案) 这个好像没法避免吧!Hibernate实体是和数据库表一一对应的,如果数据库已经存在表了,可以使用IDE自动生成实体类的。 1.在IDE中创建数据库连接。 2.通过数据源选择数据库、表,然后反向生成实体类。 详细的操作百度吧。 也用不着一次都把映射关系做好吧,用到一张表的时候去建映射关系 确实没什么好办法 可以实现 实体表  一对多。这样不科学呀,表结构一样,你还得一点点看表结构,然后再分类,用的时候,要是同时用到2个一样结构的表,你怎么封装实体呢? 逆向生成,通过表生成实体类对象和hbm文件,通过myeclipse集成的hibernate去操作,详细百度。理论上和表是一一对应的 一对多,这不科学。因为如果存在一对多的话,这表设计就不合理了,那就会出现大量冗余数据! 请使用hibernate反向工程...话说我习惯先设计数据库表,实体类从来就没自己敲过代码...最多改改 你用到自己用到什么就写什么实体类,面向对象的去思考,不要管它多少张表了,我写了这么久的代码表还没上过50.. 问下,你的问题解决了吗
http://www.itnose.net/detail/6005296.html 2014-03-05 17:36   [J2EE]

关于hibernate逆向生成实体类的问题

   小弟最近在做一个web项目,数据库时sql sever2005  我用myEclipse自带的hibernate工具 从表生成实体类的时候,为什么一个表生成了两个实体类?那我hql查询的时候应该是查哪个对象呢? 例如
http://www.itnose.net/detail/731443.html 2014-02-20 01:59   [JavaWeb]

关于hibernate实体类注解

常用的hibernate annotation标签如下: @Entity              --注释声明该类为持久。将一个Javabean声明为一 个实体的数据库表映射,最好实现序列化.此时,默认情况下,所有的类属性都为映射到数据表的持久性字段.若在中,添加另外属性,而非映射来数据库的, 要用下面的Transient来注解.  @Table(name="promotion_info")     --持久性映射的表(表名="promotion_info).@Table是一级的注解,定义在@Entity下,为实体bean映射表,目录和schema的名字,默认为实体bean的名,不带包名. @Id--注释可以表明哪种属性是该类中的独特标识符(即相当于数据表的主键)。 @GeneratedValue   --定义自动增长的主键的生成策略. @Transient             --将忽略这些字段和属性,不用持久化到数据库.适用于,在当前的持久中,某些属性不是用于映射到数据表,而是用于其它的业务逻辑需要,这时,须将这些属性进行transient的注解.否则系统会因映射不到数据表相应字段而出错. @Temporal(TemporalType.TIMESTAMP)--声明时间格式 @Enumerated         --声明枚举  @Version                --声明添加对乐观锁定的支持  @OneToOne           --可以建立实体bean之间的一对一的关联  @OneToMany         --可以建立实体bean之间的一对多的关联 @ManyToOne         --可以建立实体bean之间的多对一的关联  @ManyToMany       --可以建立实体bean之间的多对多的关联  @Formula               --一个SQL表达式?这种属性是只读的,不在数据库生成属性(可以使用sum、average、max等)  @OrderBy               --Many端某个字段排序(List)   Hibernate注解详细说 Hibernate注解详细说明 1、@Entity(name="EntityName") 必须 name为可选,对应数据库中一的个表    2、@Table(name="",catalog="",schema="") 可选 通常和@Entity配合使用,只能标注在实体的class定义处,表示实体对应的数据库表的信息 name:可选,表示表的名称.默认地,表名和实体名称一致,只有在不一致的情况下才需要指定表名 catalog:可选,表示Catalog名称,默认为Catalog(""). schema:可选,表示Schema名称,默认为Schema("").      3、@id 必须 @id定义了映射到数据库表的主键的属性,一个实体只能有一个属性被映射为主键.置于getXxxx ()前.    4、@GeneratedValue(strategy=GenerationType,generator="") 可选  strategy:表示主键生成策略,有AUTO,INDENTITY,SEQUENCE 和 TABLE 4种,分别表示让ORM 框架自动选择,根据数据库的Identity字段生成,根据数据库表的Sequence字段生成,以有根据一个额外的表生 成主键,默认为AUTO  generator:表示主键生成器的名称,这个属性通常和ORM框架相关,例如,Hibernate可以指定 uuid等主键生成方式.   generator = "uuid" :由Hibernate基于128 位唯一值产生算法生成16 进制数值(编码后以长度32 的字符串表示)作为主键。 示例:      @Id      @GeneratedValues(strategy=StrategyType.SEQUENCE)     public int getPk() {         return pk;      }  @Id @GeneratedValue(strategy=GenerationType.SEQUENCE, generator="S_Teacher")     @SequenceGenerator(name="S_Teacher",allocationSize=1,initialValue=1, sequenceName="S_Teacher")   5、@Basic(fetch=FetchType,optional=true)  可选 @Basic表示一个简单的属性到数据库表的字段的映射,对于没有任何标注的getXxxx()方法,默认 即为@Basic  fetch: 表示该属性的读取策略,有EAGER和LAZY两种,分别表示主支抓取和延迟加载,默认为EAGER. (1)、FetchType.LAZY:懒加载,加载一个实体时,定义懒加载的属性不会马上从数据库中加载。 (2)、FetchType.EAGER:急加载,加载一个实体时,定义急加载的属性会立即从数据库中加载。 (3)、比方User有两个属性,name跟address,就像百度知道,登录后用户名是需要显示出来的,此属性用到的几率极大,要马上到数据库查,用急加载;而用户地址大多数情况下不需要显示出来,只有在查看用户资料是才需要显示,需要用了才查数据库,用懒加载就好了。所以,并不是一登录就把用户的所有资料都加载到对象中,于是有了这两种加载模式。 optional:表示该属性是否允许为null,默认为true 示例:     @Basic(optional=false)      public String getAddress() {         return address;      }     6、@Column  可选 @Column描述了数据库表中该字段的详细定义,这对于根据JPA注解生成数据库表结构的工具非常 有作用. name:表示数据库表中该字段的名称,默认情形属性名称一致  nullable:表示该字段是否允许为null,默认为true unique:表示该字段是否是唯一标识,默认为false  length:表示该字段的大小,仅对String类型的字段有效 insertable:表示在ORM框架执行插入操作时,该字段是否应出现INSETRT语句中,默认为true updateable:表示在ORM框架执行更新操作时,该字段是否应该出现在UPDATE语句中,默认为 true.对于一经创建就不可以更改的字段,该属性非常有用,如对于birthday字段. columnDefinition:表示该字段在数据库中的实际类型.通常ORM框架可以根据属性类型自动判 断数据库中字段的类型,但是对于Date类型仍无法确定数据库中字段类型究竟是DATE,TIME还是 TIMESTAMP.此外,String的默认映射类型为VARCHAR,如果要将String类型映射到特定数据库的 BLOB或TEXT字段类型,该属性非常有用.  示例:     @Column(name="BIRTH",nullable="false",columnDefinition="DATE")     public String getBithday() {         return birthday;      }     7、@Transient  可选 @Transient表示该属性并非一个到数据库表的字段的映射,ORM框架将忽略该属性. 如果一个属性并非数据库表的字段映射,就务必将其标示为@Transient,否则,ORM框架默认其注 解为@Basic  示例:     //根据birth计算出age属性      @Transient      public int getAge() {         return getYear(new Date()) - getYear(birth);      }   8、@ManyToOne(fetch=FetchType,cascade=CascadeType) 可选  @ManyToOne表示一个多对一的映射,该注解标注的属性通常是数据库表的外键 optional:是否允许该字段为null,该属性应该根据数据库表的外键约束来确定,默认为true fetch:表示抓取策略,默认为FetchType.EAGER cascade:表示默认的级联操作策略,可以指定为ALL,PERSIST,MERGE,REFRESH和REMOVE中的若 干组合,默认为无级联操作 targetEntity:表示该属性关联的实体类型.该属性通常不必指定,ORM框架根据属性类型自动判 断targetEntity. 示例:      //订单Order和用户User是一个ManyToOne的关系      //在Order中定义     @ManyToOne()      @JoinColumn(name="USER")      public User getUser() {         return user;      }     9、@JoinColumn   可选 @JoinColumn和@Column类似,介量描述的不是一个简单字段,而一一个关联字段,例如.描述一个 @ManyToOne的字段. name:该字段的名称.由于@JoinColumn描述的是一个关联字段,如ManyToOne,则默认的名称由 其关联的实体决定. 例如,实体Order有一个user属性来关联实体User,则Order的user属性为一个外键, 其默认的名称为实体User的名称+下划线+实体User的主键名称  示例:      见@ManyToOne   10、@OneToMany(fetch=FetchType,cascade=CascadeType)  可选  @OneToMany描述一个一对多的关联,该属性应该为集体类型,在数据库中并没有实际字段. fetch:表示抓取策略,默认为FetchType.LAZY,因为关联的多个对象通常不必从数据库预先读取 到内存  cascade:表示级联操作策略,对于OneToMany类型的关联非常重要,通常该实体更新或删除时,其 关联的实体也应当被更新或删除  例如:实体User和Order是OneToMany的关系,则实体User被删除时,其关联的实体Order也应该 被全部删除 示例:      @OneTyMany(cascade=ALL)      public List getOrders() {         return orders;      }     11、@OneToOne(fetch=FetchType,cascade=CascadeType) 可选  @OneToOne描述一个一对一的关联  fetch:表示抓取策略,默认为FetchType.LAZY cascade:表示级联操作策略  示例:      @OneToOne(fetch=FetchType.LAZY)     public Blog getBlog() {         return blog;      }     12、@ManyToMany  可选  @ManyToMany 描述一个多对多的关联.多对多关联上是两个一对多关联,但是在ManyToMany描述 中,中间表是由ORM框架自动处理 targetEntity:表示多对多关联的另一个实体类的全名,例如:package.Book.class mappedBy:表示多对多关联的另一个实体类的对应集合属性名称  示例:     User实体表示用户,Book实体表示书籍,为了描述用户收藏的书籍,可以在User和Book之间 建立ManyToMany关联     @Entity      public class User {         private List books;  @ManyToMany(targetEntity=package.Book.class)        public List getBooks() {             return books;         }       public void setBooks(List books) {             this.books=books;         }    }            @Entity     public class Book {         private List users;         @ManyToMany(targetEntity=package.Users.class, mappedBy="books")        public List getUsers() {             return users;         }        public void setUsers(List users) {             this.users=users;         }      } 两个实体间相互关联的属性必须标记为@ManyToMany,并相互指定targetEntity属性, 需要注意的是,有且只有一个实体的@ManyToMany注解需要指定mappedBy属性,指向 targetEntity的集合属性名称 利用ORM工具自动生成的表除了User和Book表外,还自动生成了一个User_Book表,用于实现多对多关联   13、@MappedSuperclass 可选 @MappedSuperclass可以将超的JPA注解传递给子类,使子类能够继承超的JPA注解  示例:     @MappedSuperclass      public class Employee() {         ....      }            @Entity      public class Engineer extends Employee {         .....      }      @Entity      public class Manager extends Employee {         .....      }     14、@Embedded 可选 @Embedded将几个字段组合成一个,并作为整个Entity的一个属性.  例如User包括id,name,city,street,zip属性. 我们希望city,street,zip属性映射为Address对象.这样,User对象将具有id,name和 address这三个属性. Address对象必须定义为@Embededable  示例:      @Embeddable      public class Address {city,street,zip}      @Entity      public class User {         @Embedded         public Address getAddress() {             ..........         }      }
http://www.itnose.net/detail/531467.html 2014-02-08 13:36   [Hibernate]

hibernate反向生成实体类

  步骤一: window-->open Perspective-->MyEclipse Java Persistence 进行了上面的 操作后会出现一个视图DB Brower:MyEclipse Derby, 点击右键新建new一个在出现的面板Database Driver中,Driver template中选择Oracle(ThinDriver)这里以oracle软件为例,如果是mysql就选mysql的 driver name可以随意取,Connection URL就写平常的JDBC中的 URL,jdbc:oracle:thin:@127.0.0.1:1521>]:<database_name>,用户名,用户密码也是的,接下来add Jars添加oracle的驱动包,点Test Driver测试下是否可用,点击Finish完成,这时在视图中会出现你写的driver name的那个图标了,点击图标可以看到数据库中所有的表 。 步骤二: 选中项目右键 -->MyEclipse-->add Hibernate Capabilities 这里我们选择hibernate3.2然后如果需要用到在实体类 上添加注释的话那么选中紧挨着的Enable Hibernate Annotations Support 然后下一步选中一个目录存放自动生成hibernate.cfg.xml文件 下一步选中一个DB Driver中我们第一步建立的那个,    然后下一步选中一个目录(选择目录和包)存放自动生成的 HibernateSessionFactory工具 点Finish完成 步骤三: 反转,到DB Brower中那个新建的选中点开到所有表选中并且点击右键--->Hibernate Reverse Enginnering 选中目录存放将要反转出来的实体类并且勾选中Create POJO<>DB(add Hibernate mapping..用来在实体类中添加注释映射,可选可不选),选中Update Hibernate configuration..用来将生成的实体类映射到上一步生成的hibernate.cfg.xml中去, 接着再下一步到typeMapping 这里选中Hibernate type类型,再到Id Generator这里,可以设置成为native,Generate version and timestamp tag是用来在有version字样的数据库列生成表的字段时自动加上@version注解,同样可选可不选,然后点击Finish完成。 就可以回到my eclipse enterprise视图下面看到所生成的实体类以及配置文件。
http://www.itnose.net/detail/523414.html 2014-02-06 12:39   [Hibernate]

myeclipse反向生成hibernate实体类

  第二步: 新建一个WEB项目 然后选中项目右键-->MyEclipse-->add Hibernate Capabilities 如果需要用到在实体类上添加注释的话那么选中紧挨着的add Hibernate Annotations Support(据说现在都用
http://www.itnose.net/detail/519650.html 2014-02-06 10:23   [JavaEclipse]

Hibernate实体类注解的问题

中是从1到18。但是程序无论如何都是取到的从1到16的,经过测试发现,问题在用hibernate取值的话,就会是从cows数据库取值。用jdbc写,则是正确的mycows中取值。 我们用了各种方式,查配置文件,查路径,甚至重启数据库,弄了半天,好吧,要放弃了。 最后的一下,看了一下实体类。因为是注解
http://www.itnose.net/detail/470892.html 2014-01-21 18:23   [J2SE]

Hibernate中 怎样获取 实体类

我在程序中想用hibernate得到我写过的所有实体类的名,在前台做一个下拉框显示,怎样才能获得实体类的名,比如 我写了Student,Teacher,School 这3个 我想在前台下拉框里显示   麻烦各位大神帮帮忙 谢谢
http://www.itnose.net/detail/362219.html 2014-01-03-12:52   [J2EE]

hibernate实体类配置文件

; } public void setManufactory(String manufactory) { this.manufactory = manufactory; } } 我还是第一次看到用抽象映射hibernate
http://www.itnose.net/detail/183832.html 2014-01-01-12:45   [JavaEclipse]

Hibernate反转表的问题 一个关联表翻转后有实体类是xxxId 但是老师

Hibernate反转表的问题 一个关联表反转后实体类是xxxId 但是老师的就没有这个实体类? 就是很简单的 tb_role tb_user tb_user_role tb_role(roleid,rolename ) 
http://www.itnose.net/detail/864514.html 2014-02-22 01:34   [J2EE]

求助:hibernate查询返回实体类中的实体类对象值为nul

实体类A包含B对象[B也是实体类] 在dao层进行数据操作的时候,B对象的数据都读取成功并可以进行操作,单当返回给service层的时候,A的一些String、int类型的数据还在,B对象里的值都却变成了null,为什么? 回复讨论(解决方案) hibernate的延迟加载机制导致的
http://www.itnose.net/detail/33321.html 2013-12-31-15:12   [J2EE]

Hibernate解决实体类不方便的方案

前言 众所周知,Java的面向对象的机制太过强,而大家在做数据库查询时几乎都是清一色的使用实体类的List接收查询结果集,但是如果使用原生语句进行查询的时候,在使用别名、联表或者其中有聚合函数时会出一些问题,可能就再需要写实体类,再手动关联临时表。 举个栗子 比如说我要查询表中class_name
http://www.itnose.net/detail/6717418.html 2017-02-14 17:51   [Hibernate]

Hibernate】--实体类映射到数据库表

;   然后,开始建立实体类,其包括5个属性: package com.bjpowernode.hibernate; import java.util.Date; public class User { private String id; private String name
http://www.itnose.net/detail/6704595.html 2016-12-30 12:39   [Hibernate]

  1  2  3  4  5 下一页>