[Java]POJO总结

发布时间 2023-09-20 19:31:29作者: 贻我高矩

一、什么是POJO

“Plain Old Java Object”“简单java对象”,也有另外一种英文描述“Plain Ordinary Java Object”,都不影响。POJO的内在含义是指那些没有从任何类继承、也没有实现任何接口,更没有被其它框架侵入的java对象。

二、为什么会有POJO?

主要是Java的开发者被EJB的繁杂搞怕了,大家经过反思,又回归“纯洁老式”的JavaBean,即有无参构造函数,每个字段都有getter和setter的java类。

三、POJO的意义

POJO让开发者可专注于业务逻辑和脱离框架的单元测试。除此之外, 由于POJO并不须要继承框架的类或实现其接口,开发者能够极其灵活地搭建继承结构和建造应用。
POJO的意义就在于它的简单而灵活性,因为它的简单和灵活,使得POJO能够任意扩展,从而胜任多个场合,也就让一个模型贯穿多个层成为现实。
先写一个核心POJO,然后实现业务逻辑接口和持久化接口,就成了Domain Model; UI需要使用时,就实现数据绑定接口,变成VO(View Object)

四、POJO与PO、VO的区别

PO是指持久对象(persistant object持久对象)。

VO是指值对象或者View对象(Value Object、View Object)。View Object。

持久对象实际上必须对应数据库中的entity(与数据库中的字段一致),实体类与数据库表中字段不一致时,可以通过如下方法解决:

1. 与数据库表对应的PO.class
@Transient
不是数据库表字段的属性必须加@Transient注解​(import javax.persistence.Transient)

@Column
数据库表字段与result不一致时用@Column注解,例如:
@Column(name = "t_schema")
private String schema;

2. 传入参数与数据库表字段不一致:
@Param
举个例子
表字段f_schema与实体schema不一致 错误代码:
  public int update(UserExtraInfo info);
表字段f_schema与实体schema不一致 正确代码:
  public int update(@Param("info") UserExtraInfo info);

所以和POJO有所区别。比如说POJO是由new创建,由GC回收。但是持久对象是insert数据库创建,由数据库delete删除的。基本上持久对象生命周期和数据库密切相关。另外持久对象往往只能存在一个数据库Connection之中,Connnection关闭以后,持久对象就不存在了,而POJO只要不被GC回收,总是存在的。

由于存在诸多差别,因此持久对象PO(Persistent Object)在代码上肯定和POJO不同,起码PO相对于POJO会增加一些用来管理数据库entity状态的属性和方法。而ORM追求的目标就是要PO在使用上尽量和POJO一致,对于程序员来说,他们可以把PO当做POJO来用,而感觉不到PO的存在。

五、关于PO类(持久化类)

PO:Persistent Object 持久化对象。

持久化对象,在Hibernate经常会遇见这样的概念。Hibernate实体状态有三种状态:瞬时态,持久态,游离态。

1)瞬时态(暂态)

(Transient)实体在内存中自由存在,它与数据库记录无关。po在DB中无记录(无副本),po和session无关(手工管理同步)。
eg. Customer customer=New Customer();
customer.setName("eric");这里的Customer对象与数据库中的数据没有任何关联。

2)持久态(Persistent)

实体对象处于Hibernate框架的管理之中。 po在DB中有记录,po和session有关(session自动管理同步)。

3 ) 游离态(脱管态)

(Detached)处于Persistent状态的实体对象,其对应的session实例关闭后,那么此时的实体对象处于Detached态。
po在DB中有记录,po和session无关(手工同步管理)
无名态:po处于游离态时被垃圾站回收了(垃圾回收机制),没有正本,只有DB中的副本。
po处于瞬时态时被垃圾站回收了,则死亡。(唯一可以死亡的状态)

代码如下: 需要jar包:ejb3-persistence.jar

package com.rcoginion.test;

import java.io.Serializable;

import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Table;

import org.springframework.data.annotation.Id;

@Entity
@Table(name = "USER")
public class ContractAttachPO  implements Serializable{

    /**
     * 序列号版本
     */
    private static final long serialVersionUID = 1393027357708703114L;
    
    // Fields
    
    /**
     * 合同id.
     */
    private Long userId;

    /**
     * 用户名.
     */
    private String userName;
    
    /**
     * 获取 .
     */
    @Id
    @GeneratedValue(generator = "S_USER_ID")
    @Column(name = "USER_ID", precision = 16, scale = 0)
    public Long getUserId() {
        return userId;
    }

    /**
     * 设置 .
     */
    public void setUserId(Long userId) {
        this.userId = userId;
    }

    /**
     * 获取 .
     */
    @Column(name = "USER_NAME")
    public String getUserName() {
        return userName;
    }

    /**
     * 设置 .
     */
    public void setUserName(String userName) {
        this.userName = userName;
    }
}
/***
注释说明:
 1.@Entity  //说明此java类是实体类 
 2.@org.hibernate.annotations.GenericGenerator(name = "S_USER_ID", strategy = "sequence",parameters
    = { @Parameter(name = "sequence", value = "S_USER_ID") }) 导入import org.hibernate.annotations.
    Parameter,是自动生成oracle序列的方法。调用创建好的序列:S_USER_ID来自动生成。
3.@Id //说明是主键(@Id此注解不能省略,不然Hibernate在调用po进行ORM操作的时候,会出现错误,千万不要
    认为主键不是自增,就不用指定主键了) @GeneratedValue(generator = "S_USER_ID")  //主键的生成方式
 4.@Table(name = "USER")           //指定数据库对应的表
 5.@Column(name = "USER_NAME")     //数据库字段和类属性对应关系 
   @Column注解配置项还有很多,具体可以了解javax.persistence的注解说明
*/