Monthly Archive: April, 2017

JAVAEE 之 PO、VO、BO、DTO、POJO、DAO

PO:

persistant object 持久对象
最形象的理解就是一个PO就是数据库中的一条记录。
好处是可以把一条记录作为一个对象处理,可以方便的转为其它对象。

BO:

business object 业务对象

主要作用是把业务逻辑封装为一个对象。这个对象可以包括一个或多个其它的对象。
比如一个简历,有教育经历、工作经历、社会关系等等。
我们可以把教育经历对应一个PO,工作经历对应一个PO,社会关系对应一个PO。
建立一个对应简历的BO对象处理简历,每个BO包含这些PO。
这样处理业务逻辑时,我们就可以针对BO去处理。

VO :

value object 值对象
ViewObject 表现层对象

主要对应界面显示的数据对象。对于一个WEB页面,或者SWT、SWING的一个界面,用一个VO对象对应整个界面的值。

DTO :

Data Transfer Object 数据传输对象
主要用于远程调用等需要大量传输对象的地方。
比如我们一张表有100个字段,那么对应的PO就有100个属性。
但是我们界面上只要显示10个字段,客户端用WEB service来获取数据,没有必要把整个PO对象传递到客户端,这时我们就可以用只有这10个属性的DTO来传递结果到客户端,这样也不会暴露服务端表结构.到达客户端以后,如果用这个对象来对应界面显示,那此时它的身份就转为VO

POJO :

plain ordinary java object 简单Java对象
个人感觉POJO是最常见最多变的对象,是一个中间对象,也是我们最常打交道的对象。

一个POJO持久化以后就是PO
直接用它传递、传递过程中就是DTO
直接用来对应表示层就是VO

DAO:

data access objec t数据访问对象
这个大家最熟悉,和上面几个O区别最大,基本没有互相转化的可能性和必要.
主要用来封装对数据库的访问。通过它可以把POJO持久化为PO,用PO组装出来VO、DTO

MyBatis 使用详解

什么是 MyBatis ?

MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的持久层框架。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以对配置和原生Map使用简单的 XML 或注解,将接口和 Java 的 POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。

如果使用 Maven 来构建项目,则需将下面的 dependency 代码置于 pom.xml 文件中:

<dependency>
	<groupId>org.mybatis</groupId>
	<artifactId>mybatis</artifactId>
	<version>3.4.2</version>
</dependency>

配置Mybatis

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
  PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
	<!-- 配置全局属性 -->
	<settings>
		<!-- 使用jdbc的getGeneratedKeys获取数据库自增主键值 -->
		<setting name="useGeneratedKeys" value="true" />
		<setting name="cacheEnabled" value="true"/>
		<!-- 使用列别名替换列名 默认:true -->
		<setting name="useColumnLabel" value="true" />

		<!-- 开启驼峰命名转换:Table{create_time} -> Entity{createTime} -->
		<setting name="mapUnderscoreToCamelCase" value="true" />
	</settings>

	<!-- 别名 -->
	<typeAliases>
		<package name="com.pay.entity" />
		<!--<typeAlias type="com.pay.entity.Student" alias="Student"/>-->
	</typeAliases>

	<!-- 基于注解的配置 -->
	<mappers>
		<!--<mapper class="com.pay.dao.IStudentDao"/>-->
		<!--<mapper class="com.pay.dao.IManagerDao"/>-->
		<!--<mapper class="com.pay.dao.IPaymentInfoDao"/>-->
		<package name="com.pay.dao"/>
	</mappers>

</configuration>

定义实体Bean

package com.pay.entity;

public class Manager {
    private Integer id;

    private String username;

    private String userpwd;

    private String email;

    public Manager(Integer id, String username, String userpwd, String email) {
        this.id = id;
        this.username = username;
        this.userpwd = userpwd;
        this.email = email;
    }

    public Manager() {
        super();
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username == null ? null : username.trim();
    }

    public String getUserpwd() {
        return userpwd;
    }

    public void setUserpwd(String userpwd) {
        this.userpwd = userpwd == null ? null : userpwd.trim();
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email == null ? null : email.trim();
    }

    @Override
    public String toString() {
        StringBuilder sb = new StringBuilder();
        sb.append(getClass().getSimpleName());
        sb.append(" [");
        sb.append("Hash = ").append(hashCode());
        sb.append(", id=").append(id);
        sb.append(", username=").append(username);
        sb.append(", userpwd=").append(userpwd);
        sb.append(", email=").append(email);
        sb.append("]");
        return sb.toString();
    }
}

定义Dao接口

package com.pay.dao;

import com.pay.entity.Manager;

import java.util.List;

public interface IManagerDao {
    /**
     * 添加一个管理员
     * @param bean 管理实体类
     */
    public void add(Manager bean);

    /**
     * 查询管理用户
     * @param userName 用户名
     * @param userPwd 用户密码
     * @return 一个管理角色对象
     */
    public Manager findUser(String userName,String userPwd);

    /**
     * 更改管理员密码
     * @param userName 用户名
     * @param newPwd 用户新密码
     */
    public void updatePwd(String userName,String newPwd);

    /**
     * 查询所有管理员用户
     * @return 管理员集合
     */
    public List<Manager> findAll();
}

定义Mapper配置文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.pay.dao.IManagerDao">

  <!-- 缓存配置 -->
  <cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>

  <resultMap id="ManagerResultMap" type="com.pay.entity.Manager">
    <constructor>
      <idArg column="id" javaType="java.lang.Integer" jdbcType="INTEGER" />
      <arg column="userName" javaType="java.lang.String" jdbcType="VARCHAR" />
      <arg column="userPwd" javaType="java.lang.String" jdbcType="VARCHAR" />
      <arg column="email" javaType="java.lang.String" jdbcType="VARCHAR" />
    </constructor>
  </resultMap>
  <sql id="ManagerList">
    id, userName, userPwd, email
  </sql>

  <!-- 添加管理员 -->
  <insert id="add" parameterType="com.pay.entity.Manager">
    insert into manager (userName, userPwd,
      email)
    values (#{username,jdbcType=VARCHAR}, #{userpwd,jdbcType=VARCHAR},
      #{email,jdbcType=VARCHAR})
  </insert>

  <!-- 查询管理员 -->
  <select id="findUser" resultMap="ManagerResultMap">
    select <include refid="ManagerList"/> from manager where userName = #{userName} and userPwd = #{userPwd}
  </select>

  <!-- 更改管理员密码 -->
  <update id="updatePwd">
    UPDATE manager SET userPwd = #{userPwd} where userName = #{userName}
  </update>

</mapper>

 

IDEA设置记录

  1. 修改为Eclipse快捷键
    File -> Settings -> Keymap => Keymaps改为 Eclipse copy
  2. 显示行号:
    File -> Settings -> Keymap ->Editor ->General -> Appearance =>Show line numbers选中
  3. 修改智能提示快捷键
    File -> Settings -> Keymap -> Main menu -> Code -> Completion -> Basic=>修改为Ctrl+Alt+Enter 保存时把冲突的Remove掉。
  4. 查找快捷键冲突问题处理
    File -> Settings -> Keymap -> Main menu -> Edit ->Find =>修改Find...和Replace...分别改为Ctrl+F 和Ctrl+R
  5. 代码智能提示大小写
    File -> Settings ->Eidtor->General->Code Completion => Case sensitive completion 改为none
  6. svn 不能同步代码问题修正
    File -> Settings ->Subversion ->General => Use command line client 去掉选中
  7. 常用快捷键
    • Alt+回车 导入包,自动修正
    • Ctrl+N 查找类
    • Ctrl+Shift+N 查找文件
    • Ctrl+Alt+L 格式化代码
    • Ctrl+Alt+O 优化导入的类和包
    • Alt+Insert 生成代码(如get,set方法,构造函数等)
    • Ctrl+E或者Alt+Shift+C 最近更改的代码
    • Ctrl+R 替换文本
    • Ctrl+F 查找文本
    • Ctrl+Shift+Space 自动补全代码
    • Ctrl+空格 代码提示
    • Ctrl+Alt+Space 类名或接口名提示
    • Ctrl+P 方法参数提示
    • Ctrl+Shift+Alt+N 查找类中的方法或变量
    • Alt+Shift+C 对比最近修改的代码
    • Shift+F6 重构-重命名
    • Ctrl+Shift+先上键
    • Ctrl+X 删除行
    • Ctrl+D 复制行
    • Ctrl+/ 或 Ctrl+Shift+/ 注释(// 或者/*...*/ )
    • Ctrl+J 自动代码
    • Ctrl+E 最近打开的文件
    • Ctrl+H 显示类结构图
    • Ctrl+Q 显示注释文档
    • Alt+F1 查找代码所在位置
    • Alt+1 快速打开或隐藏工程面板
    • Ctrl+Alt+ left/right 返回至上次浏览的位置
    • Alt+ left/right 切换代码视图
    • Alt+ Up/Down 在方法间快速移动定位
    • Ctrl+Shift+Up/Down 代码向上/下移动。
    • F2 或Shift+F2 高亮错误或警告快速定位
    • 代码标签输入完成后,按Tab,生成代码。
    • 选中文本,按Ctrl+Shift+F7 ,高亮显示所有该文本,按Esc高亮消失。
    • Ctrl+W 选中代码,连续按会有其他效果
    • 选中文本,按Alt+F3 ,逐个往下查找相同文本,并高亮显示。
    • Ctrl+Up/Down 光标跳转到第一行或最后一行下
    • Ctrl+B 快速打开光标处的类或方法
  8. 设置idea的SVN忽略掉*.iml文件
    Editor->File Types=>Ignore files and folders增加*.iml;
  9. 改编编辑区文本字体
    File -> settings -> EDITOR COLORS & FONTS -> FONT -> SIZE
  10. IEDA编码设置
    FILE -> SETTINGS -> FILE ENCODINGS => IDE ENCODING
    FILE -> SETTINGS -> FILE ENCODINGS => Project Encoding
    FILE -> SETTINGS -> FILE ENCODINGS => Default encoding for properties files
    FILE -> SETTINGS -> FILE ENCODINGS => Transparent native-to-ascii conversion
  11. System.out.println 快捷输出
    “abc”.sout => System.out.println("abc");
  12. for循环