5.1.7 默认实体映射

一个类标注了@Entity,该类就成为了一个可持久化的类。如果不标注任何注释,这个类的属性和方法将自动映射为数据库中默认的表和字段。

例如,以下这个实体类的代码。

@Entity

public class ContactEO implements java.io.Serializable {

 

         public ContactEO() {

         }

 

         private Integer id;

 

         public Integer getId() {

                   return id;

         }

 

         public void setId(Integer id) {

                   this.id = id;

         }

 

         private String name;

 

         public String getName() {

                   return name;

         }

 

         public void setName(String name) {

                   this.name = name;

         }

}

该实体默认对应的数据库中的表名为“contacteo”,属性id默认映射为表中的字段“id”,属性name默认映射为表中的字段“name”,默认映射的创建表的SQL脚本如下所示。

CREATE TABLE  contacteo (

  id int(20) NOT NULL,

  name varchar(50) default NULL

) ENGINE=MyISAM DEFAULT CHARSET=latin1;

若此时,换成同样的表结构,只是表明和字段名不一样,表的SQL脚本改为:

CREATE TABLE  contact (

  contact_id int(20) NOT NULL,

  contact_name varchar(50) default NULL

) ENGINE=MyISAM DEFAULT CHARSET=latin1;

则实体的代码将修改为:

@Entity

@Table(name=”contact”)

public class ContactEO implements java.io.Serializable {

         ……

private Integer id;

 

         @Column(name=”contact_id”)

         public Integer getId() {

                   return id;

         }

……

 

         private String name;

 

         @Column(name=”contact_name”)

         public String getName() {

                   return name;

         }

……

}

@Table注释可以定义所映射表的具体配置,@Column注释可以定义所映射的字段配置。实体的映射虽然有默认的映射,大多数情况下,要根据数据库表结构进行自定义的配置。接下来,就学习一下如何具体设置映射。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值