ORM

关系数据库需要按对象来处理,出现ORM设置,列对应类的属性,行对应对应类的实例,也就是每一行对应一个新的实例,对应类是需要实现序列化(implements Serializable  - import java.io.Serializable),这些对应类称为持久化对象,是数据层DAO,Domain,向下直接对应数据库,向上接服务层,它们的属性是对应数据库的列,方法是对数据库的操作,比如,先设定一个公共基类,可以完成,一般表的createby,createddate,modifiedby,modifieddate这4个常用字段的添加,最好将分页属性也放进去,再将这些对应类建立,这些对应类应该是继承基类,并且,对应数据表的(可以是单表结构,单表查询结果,多表查询结果,查询结果添加自定义字段的,查询结果进行转换过的等等 - 引申为po,dto),对这些类的方法中实现具体操作(可以建立接口( interface IBasicService<T> ->CURD同find、getAll,getCount。。。  )同DAOImpl这样的实现类 (

引申扩展服务层(serice类,封装业务流程)一般流程:

1.Interface:

public interface ICustomerService {

定义各种方法,只是定义,实现可以交代其他人来写了。。。

PageInfo<CustomerContactVo> queryCustomerContactList(CustomerContactVo contactVo) throws Exception;

}

2.service:

实现接口,实现接口中定义的方法,对数据层进行调用:

public class CustomerServiceImpl implements ICustomerService{

private static final Logger logger = LoggerFactory.getLogger(CustomerServiceImpl.class);

...

//对DAO进行调用,其中interface  ICustomerDao ->  CustomerDaoImpl implements  ICustomerDao {}

@Resource
private ICustomerDao customerDao; //下面方法没有用到,只是举个DAO层例子,这个DAO接口实现的方法将对数据库进行操作,对业务需求进行实现,引申为服务层用DAO接口方式同数据层解耦(业务层不依赖持久层),这个接口可以选择任何数据库来实现,高层不依赖低层(依赖倒转原则),依赖抽象,面对接口编程。

...

@Override
public PageInfo<CustomerContactVo> queryCustomerContactList(CustomerContactVo contactVo) throws Exception {
PageHelper.startPage(contactVo.getPage(), contactVo.getRows());
PageInfo<CustomerContactVo> customerContact = null;

try {
if (!StringUtils.isBlank(contactVo.getApplicationQuery())) {
UserInfo userInfo = (UserInfo) Core.cache().get(contactVo.getToken());
if (null != userInfo) {
contactVo.setCreatedBy(userInfo.getId());
}
}
customerContact = new PageInfo<CustomerContactVo>(customerDao.queryCustomerContactById(contactVo));
} catch (Exception e) {
// DAO exception 处理
}

return customerContact;
}

}

3.api (servlet/controller/action):

@Controller
@RequestMapping(value = "/customer")
@Api(value = "/customer")
public class CustomerApi extends BasicApi<Object> {

@Reference(timeout = 100000)

private ICustomerService customerService; //同上面服务实现DAO接口实现一样,这里是表示层对服务接口的调用,让表示层不依赖于业务层

@RequestMapping(value = "/queryCustomerContactList", method = RequestMethod.POST)
public @ResponseBody Object queryCustomerContactList(CustomerContactVo contactVo, HttpServletRequest request)
throws JsonProcessingException {
if (ObjectUtils.isEmpty(contactVo)) {
throw new Exception("E04", "", null);
}
Object object = sendDataTablePageAjaxData(customerService.queryCustomerContactList(contactVo));
return object;
}

}

4.Html

Html,css,javascript,Jquery,bootstrap,vue,ios,android...

->XML JSON

->HTTP AJAX

->HTTP

)来做,也可以不用,如果考虑多个数据库切换最好做,比如:mssqlImpl implements IBasicService()):

public class BasicDomain implements Serializable {

private static final long serialVersionUID = 6686489176603998566L;

/**
* 前台传入参数:当前页
*/
private int page = 1;
/**
* 前台传入参数:每页页数
*/
private int rows = 10;
/**
* 前台传入参数:排序字段
*/
private String sidx;
/**
* 前台传入参数:排序类型
*/
private String sord;
/**
* 数据库分页参数:当前页
*/
private int start;

/**
* 数据库分页参数:每页页数
*/
private int limit = 10;

/**
* 创建时间
*/
private Date createdDate;
/**
* 创建人
*/
private String createdBy;
/**
* 修改时间
*/
private Date modifiedDate;
/**
* 修改人
*/
private String modifiedBy;

。。。

getter/setter

。。。

}

//PO

public class Customer extends BasicDomain {
/**
*
*/
private static final long serialVersionUID = 1L;
private String customerID;
private Long accountID;// 客户ID
private String name;// 名称
private String number;// 编号

。。。

//非实体关联关系属性,仅供方便传参
private CustomerExt customerExt;
private CustomerBankInfo customerBankInfo;

//可以List VO ,VO是业务层的数据传递,也是前端显示数据,比如,DTO(DTO类封装业务实体对象)是0同1,那么VO是男同女,view同model要避免强耦合,

private List<CustomerAddressVO> customerAddressList;

public CustomerBankInfo getCustomerBankInfo() {
return customerBankInfo;
}

public List<CustomerAddressVO> getCustomerAddressList() {
return customerAddressList;
}

public void setCustomerBankInfo(CustomerBankInfo customerBankInfo) {
this.customerBankInfo = customerBankInfo;
}

public void setCustomerAddressList(List<CustomerAddressVO> customerAddressList) {
this.customerAddressList = customerAddressList;
}

。。。

}

一般带上下面3个:

@Override
public int hashCode() {

@Override
public boolean equals(Object obj) {

@Override
public String toString() {

Mybatis的学习1的更多相关文章

  1. Mybatis架构学习

    Mybatis架构学习 MyBatis 是支持定制化 SQL.存储过程以及高级映射的持久层框架.MyBatis 封装了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.可以对配置和原生Map使用 ...

  2. MyBatis入门学习教程-使用MyBatis对表执行CRUD操作

    上一篇MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对use ...

  3. MyBatis入门学习(二)

    在MyBatis入门学习(一)中我们完成了对MyBatis简要的介绍以及简单的入门小项目测试,主要完成对一个用户信息的查询.这一节我们主要来简要的介绍MyBatis框架的增删改查操作,加深对该框架的了 ...

  4. Mybatis的学习总结二:使用Mybatis对表进行CRUD操作【参考】

    一.使用Mybatis对表进行CRUD操作------基于XML的实现 1.定义SQL的映射文件 2.在conf.xml中进行注册. 2.创建测试类 [具体过程参考:Mybatis的学习总结一] 二. ...

  5. Spring+SpringMVC+MyBatis深入学习及搭建(二)——MyBatis原始Dao开发和mapper代理开发

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6869133.html 前面有写到Spring+SpringMVC+MyBatis深入学习及搭建(一)——My ...

  6. Spring+SpringMVC+MyBatis深入学习及搭建(三)——MyBatis全局配置文件解析

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6874672.html 前面有写到Spring+SpringMVC+MyBatis深入学习及搭建(二)——My ...

  7. Spring+SpringMVC+MyBatis深入学习及搭建(四)——MyBatis输入映射与输出映射

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6878529.html 前面有讲到Spring+SpringMVC+MyBatis深入学习及搭建(三)——My ...

  8. Spring+SpringMVC+MyBatis深入学习及搭建(五)——动态sql

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6908763.html 前面有讲到Spring+SpringMVC+MyBatis深入学习及搭建(四)——My ...

  9. Spring+SpringMVC+MyBatis深入学习及搭建(六)——MyBatis关联查询

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6923464.html 前面有将到:Spring+SpringMVC+MyBatis深入学习及搭建(五)--动 ...

  10. Spring+SpringMVC+MyBatis深入学习及搭建(七)——MyBatis延迟加载

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6953005.html 前面讲到:Spring+SpringMVC+MyBatis深入学习及搭建(六)——My ...

随机推荐

  1. python之format函数

    自python2.6开始,新增了一种格式化字符串的函数str.format(),可谓威力十足.那么,他跟之前的%型格式化字符串相比,有什么优越的存在呢?让我们来揭开它羞答答的面纱. 语法 它通过{}和 ...

  2. Day14全局变量与局部变量

    列表的所有方法都可以用,如remove  clear 为了避免容易出错,全局变量名用大写,局部变量名用小写  nonlocal指上一级的name

  3. DLL简单分析与调用方法

    最近为了分析一个没有代码的DLL有哪些函数,找了各种方法. 把结果分享一下:三个方法都没法得到函数的参数,有点让我失望. DLL Export Viewer NikPEViewer Dumpbin 配 ...

  4. Elisp 中变量赋值函数 set 与 setq 辨析

    在 Elisp 中,为变量赋值的函数有 set 与 setq,但是,两者存在很大的差异. 使用 set 赋值: 如果我们想为变量 flowers 赋值为一个 列表 '(rose violet dais ...

  5. C# 利用Unity 实现IOC+AOP

    public interface INoticy { void Noticy(string msg); } public class SMSNoticy : INoticy { public void ...

  6. hex转mif文件 verilog

    用FPGA来跑ARM 核的时候,刚开始将Keil编译产生的hex文件拿来仿真和下到板子上的时候,发现程序运行不正确.细细观察仿真波形发现,在Altera的ROM IP中直接调用Keil产生的hex文件 ...

  7. VS2017离线版的SSDT安装包(包括SSIS)

    VS2017离线版的SSDT安装包(包括SSIS) 装好SQL2016和VS2017后发现没有创建SSIS项目的接口,原来VS2017里是没有包含SSDT的安装包的. 下面是我整理好的包含中英文的VS ...

  8. 移植QT库的问题:QT_INSTALL/include/QtCore/qatomic_arm.h:131: Error: no such instruction: `swpb %al,

    解决办法:错误信息说明编译器未识别swpb汇编操作,指令集有问题.把配置命令改成: ./configure -embedded armv7 -prefix /home/thwijeth/Softwar ...

  9. kettle在centos7下部署分布式集群

    首先安装三台centos7 ,分别配置好静态ip    ssh免密码登录     关闭防火墙 具体步骤这里不多说了 关于centos7配置静态ip大家可以参考:https://www.cnblogs. ...

  10. Linux中常用目录作用

    Linux一般相应的文件都会会放在相应的目录下.这样更有利于文件的查找. 1.可以在家目录root或home,以及temp目录下随便放东西. 2.根目录下的bin和sbin,usr目录下的bin和sb ...