Mybaitis配置总结
- 在mybatis-config.xml中配置分页插件,插件配置必须放在mapper前面
<plugins>
<plugin interceptor="com.rrtong.frame.dao.PaginationInterceptor">
<property name="dialect" value="oracle"/>
</plugin>
</plugins>
- Mybatis分页拦截器获取sql
/*以下得到的是要执行的sql语句,并不是配置的sql语句*/
StatementHandler statementHandler = (StatementHandler)invocation.getTarget();
BoundSql boundSql = statementHandler.getBoundSql();
String originalSql = boundSql.getSql();
- 出现java.lang.AbstractMethodError: org.mybatis.spring.transaction.SpringManagedTransactionFactory.newTransaction(Ljava/sql/Connection;)Lorg/apache/ibatis/transaction/Transaction;
版本不正确,需要使用更高版本的 mybatis-spring
https://mybatis.googlecode.com/files/mybatis-spring-1.2.1.zip
- Mybaitis参数严格区分大小写
mybatis 配置文件中的参数绑定区分大小写,必须与传递的参数名保持一致
- 出现数据类型111时,这是因为数据库字段数据类型与entity中的字段定义的数据类型不一致导致的,有以下两种方法解决
1、设定entity的数据类型与数据库类型一致
2、在sql中定义参数的数据类型,比如
where userCode = #{userCode, jdbcType=VARCHAR}
- 实现数据库字段与实体字段的关系对应
<resultMap id="Archive" type="Archive">
<id column="ARCHIVESKEY" property="archiveKey" />
<result column="title" property="archiveTitle" />
</resultMap>
- 定义oracle数据库的mybatis获取主键并返回的配置,mybatis before after设置
<p> <selectKey keyProperty="archiveKey" order="BEFORE" resultType="String">
SELECT SEQ_ARCHIVE.NEXTVAL
FROM DUAL
</selectKey></p>
- 定义其他数据库的Mybatis获取主键并返回的配置
<insert id="insertUser" useGeneratedKeys="true" keyProperty="userId" parameterType="com.mybatis.User">
insert into user(userName,password)
values(#{userName},#{password})
</insert>
- 定义mybatis查询结果注入到实体中
<resultMap id="Archive" type="Archive">
<id column="SPAARCHIVESKEY" property="archiveKey" />
<result column="title" property="archiveTitle" />
</resultMap> <select id="getArchive" parameterType="HashMap" resultMap="Archive">
select
SPAARCHIVESKEY,
TITLE
from Archives
where USERCODE = #{userCode, jdbcType=VARCHAR}
And VALID= #{valid, jdbcType=VARCHAR}
</select>
- 定义Mybaitis更新数据库表记录
<update id="updateArchive" parameterType="Archive">
update Tbl_ARCHIVES
set
title = #{archiveTitle},
content = #{content},
feeValue = #{feeValue}
security = #{security},
subjectType = #{subjectType},
gradeType = #{gradeType},
gather = #{gather},
archiveType = #{archiveType},
keyWordName = #{keyWordName}
where archivesKey = #{archiveKey}
</update>
- 定义mybatis删除数据表记录的方式
<delete id="deleteArchive" parameterType="String">
delete from title
where spaArchivesKey = #{archiveKey}
</delete>
- 定义公共的sql语句,允许复用
<sql id="addrColumn">
a.PUSH_ID,
a.MEMBER_ID,
a.CONTENT,
a.PHOTO,
a.PUSH_NAME,
a.IS_AUTO,
a.IS_FINE,
a.IS_SOURCE,
a.SOURCE_PUSH_ID,
DATE_FORMAT(a.CREATE_TIME,'%Y-%m-%d %H:%i:%s') CREATE_TIME,
DATE_FORMAT(a.DELETE_TIME,'%Y-%m-%d %H:%i:%s') DELETE_TIME
</sql>
引用复用的sql语句
<select id="getMyOrFineBlog" parameterType="MicroBlog" resultType="MicroBlog">
SELECT
<include refid="addrColumn"/>
FROM TBL_BLOG_PUSH a, TBL_USER_MEMBER b
WHERE a.MEMBER_ID = b.MEMBER_ID
<if test="isFine == 1"> AND a.IS_FINE = #{isFine} </if>
</select>
Mybaitis配置总结的更多相关文章
- mybaitis配置信息
在配置mybatis当中,jdbcType的名称要大写,时间类型DATE只能传入年月日,要想传入时分秒,应该使用TIMESTAMP http://www.blogjava.net/hello-yun/ ...
- 01-电子商城项目介绍及ssm框架搭建
1.B2C电商项目功能及架构 1.1功能列表 1.2系统架构(soa架构) 2.后台管理系统工程搭建及测试 ypMall,ypMall-manager-web ypMall为父项目,管理子项目的jar ...
- Spring、SpringMVC、Mybaitis框架配置
给大家推荐2个网址,介绍的非常详细 SSM环境搭建 http://blog.csdn.net/zhshulin/article/details/37956105 SSM代码生成工具介绍 http:// ...
- java web后台开发SSM框架(Spring+SpringMVC+MyBaitis)搭建与优化
一.ssm框架搭建 1.1创建项目 新建项目后规划好各层的包. 1.2导入包 搭建SSM框架所需包百度云链接:http://pan.baidu.com/s/1cvKjL0 1.3整合spring与my ...
- 缓存策略 半自动化就是mybaitis只支持数据库查出的数据映射到pojo类上,而实体到数据库的映射需要自己编写sql语句实现,相较于hibernate这种完全自动化的框架我更喜欢mybatis
springboot入门(三)-- springboot集成mybatis及mybatis generator工具使用 - FoolFox - CSDN博客 https://blog.csdn.net ...
- spring mvc整合mybaitis和log4j
在上一篇博客中,我介绍了在mac os上用idea搭建spring mvc的maven工程,但是一个完整的项目肯定需要数据库和日志管理,下面我就介绍下spring mvc整合mybatis和log4j ...
- IDEA 安装配置及操作总结(新手必看)
Jetbrains官网下载IDEA15 我们在浏览器输入网址https://www.jetbrains.com/.选择相应的系统版本,下载最新版本的IDEA15,Windows系统双击安装文件,根据界 ...
- 配置android sdk 环境
1:下载adnroid sdk安装包 官方下载地址无法打开,没有vpn,使用下面这个地址下载,地址:http://www.android-studio.org/
- Android Studio配置 AndroidAnnotations——Hi_博客 Android App 开发笔记
以前用Eclicps 用习惯了现在 想学学 用Android Studio 两天的钻研终于 在我电脑上装了一个Android Studio 并完成了AndroidAnnotations 的配置. An ...
随机推荐
- 【Xamarin开发 Android 系列 3】循序渐进的学习顺序
原文:[Xamarin开发 Android 系列 3]循序渐进的学习顺序 指定合理的学习步骤,将各个技术点进行强化.慢慢 的就从点到线 到面的飞跃,一切仅仅是时间问题,开始前,请记住,学习是最佳的投资 ...
- 合并 ios 静态库
合并 cordovaLib库: lipo -create 'Release-iphoneos/libCordova.a' "Release-iphonesimulator/libCordov ...
- 《unix网络编程》笔记
inet_pton和inetntop函数.字母p和n代表presentation和numeric.地址的表达presentation格式通常是ASCIL串,数值(numeric)格式则是存在于套接字地 ...
- C++小知识之Vector用法
tyle="margin:20px 0px 0px; font-size:14px; line-height:26px; font-family:Arial; color:rgb(51,51 ...
- C#程序集使用强名字(Strong Name)签名/强名称签名
强名称签名的方法: 强签名: 1. 可以将强签名的dll注册到GAC,不同的应用程序可以共享同一dll. 2. 强签名的库,或者应用程序只能引用强签名的dll,不能引用未强签名的dll,但是未强签名的 ...
- HDU 1162 Eddy's picture
坐标之间的距离的方法,prim算法模板. Eddy's picture Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32 ...
- linux下jdk的卸载与安装
JDK的卸载 1.检查jdk的是否安装,显示如下表示安装: [root@localhost ~]# rpm -aq|grep java tzdata-java-2010l-1.el6.noarch j ...
- C#4.0中var和dynamic的区别
1. var表示“变量的类型是在编译时决定的”, var让你在初始化变量时少输入一些字,编译器会根据右值来推断出变量的类型, var只能用于局部变量的定义,你不能把类的属性定义成 var,也不能把方法 ...
- wojilu中的路由
要看2个地方,一个是route.config,另一个是wojilu.Members.Sites.Domain.SiteMenu.config,这2部分综合起作用.
- Python手动构造Cookie模拟登录后获取网站页面内容
最近有个好友让我帮忙爬取个小说,这个小说是前三十章直接可读,后面章节需要充值VIP可见.所以就需要利用VIP账户登录后,构造Cookie,再用Python的获取每章节的url,得到内容后再使用 PyQ ...