上期咱们经过对数据库的分析,仔仔细细的探索了一遍WordPress程序运行时候文章提交和草稿提交的区别和共同点,简略的归纳下以下:html
···java
更为详细的文章,建议去个人上一篇文章查看。sql
既然咱们已经大概明白了怎么去实现,那么如今咱们须要的就是进行实验。数据库
首先老规矩,先从咱们的dao层实现开始,咱们争取把各个功能模块解耦,那么咱们就不能过于在dao层限制,因此咱们须要在dao层实现数据(文章、草稿、历史记录)插入。因此咱们先生成dao接口以下:设计模式
上面的语句中咱们能够看到在mapper的insert语句块中咱们插入了selectKey语句块,主要是用来返回咱们插入的条目的自增id。为何这里咱们非要获取到插入的id呢?主要是文章生成后的日志记录都是须要文章id才能生成对应的日志记录。mybatis
同时在inset语句块中,咱们使用了choose+when语句块生成了动态sql,这样就能动态的选择程序执行。app
同时在上面的代码中咱们能够看到上面的when和下面的when语句块中关于bean的属性获取使用方式不同!ide
重点:扩展类型,要使用父类的属性时,必须是对象名.属性名的形式,对象名从dao的接口设置。(不然直接使用属性的时候,会异常提示空指针,且提示对象的属性中没有该属性)工具
1.在mapper中使用属性时,最好是对象名.属性名的方式,同时在dao层中设置对象的名称(在咱们上面dao层的add接口中有说明)post
2.mybatis的动态sql能够减小不少额外的方法和mapper中的sql编写,因此必须掌握动态sql
3.当属性较多的时候,咱们必定不能忘记单元测试,单元测试能够简单直观的了解到哪里出错,减小在后续开发中错误检查的时间。
上面咱们也是提到过单元测试,那么咱们如今看看这个dao的单元测试应该如何完成呢?
首先给你们看看咱们文章的bean:
说实话,一看到这里的时候,我也很惆怅。灵机一动,感受能够祭出这个系列教程咱们本身手写的第一个设计模式了!开启咱们的javaBean的建造者模式。
那么咱们ben生成好了后,咱们就须要开始写咱们的单元测试,以下:
你们能够看到上面咱们的PostCustom仍是从咱们本身手动封装的PostInitUtils中获取的,同时咱们的PostCustom仍是咱们的PostBean的子类。因此这里就用到了传说中的pojo包装类型相关的一些知识(咱们这里并无包装,不过已经用到了扩展类),让咱们接着看看PostInitUtils的代码:
这里咱们能够看到咱们对外开放的核心也就文章核心信息相关的一些东西了,那么这样咱们就能很好的控制数据。
如今咱们能够看下数据库,最新多出来的数据和文章首页插入的数据以下:
咱们今天的主干内容到此基本完成,剩下的从dao到前台界面适配等等基本上骚年们本身均可以完成至此不在赘述。