MyBatis从入门到精通:insert用法
2.4.1 简单的insert方法
1.接口类中的方法:
int insert(SysUser sysUser);
2.映射文件中的修改:
<!--
insert标签包含如下的属性:
id:
parameterType:即将传入的语句参数的完全限定类名或别名。这个属性是可选的,
因为MyBatis可以推断出传入语句的具体参数,因此不建议配置该属性。(这个
就是接口方法的形式参数!!!)
flushCache:默认值为true,任何时候只要语句被调用,都会清空一级二级缓存
timeout:设置在抛出异常之前,驱动程序等待数据库返回请求结果的秒数
========================这个对应与JDBC的statement=====================
statementType:对于STATEMENT,PREPARED,CALLABLE,MyBatis会分别使用
对应的Statement、PreparedStatement、CallableStatement,默认值为PREPARED
====================================================================
===============================这两个是一组的=========================
useGeneratedKeys:默认值是false,如果设置为true,MyBatis会使用JDBC的get
GeneratedKeys方法来取出由数据库内部生成的主键
keyProperty:MyBatis通过GeneratedKeys获取主键值后将要赋给的属性名。如果希望
得到多个数据库自动生成的列,属性值也可以是以逗号分割的属性名列表。
====================================================================
================================不懂=================================
keyColumn:仅对INSERT和UPDATE有用,通过生成的键值设置表中的别名,这个设置仅在某些
数据库中是必须的。
databaseId:如果配置了databaseIdProvider,Mybatis会加载所有的不带databaseId的
或者匹配当前databaseId的语句。
=====================================================================
为了放置出错,对于一些特殊的数据类型,建议指定具体的jdbcType值。例如headImg指定BLOB类型
createTime指定TIMESTAMP类型。BLOB对应的类型是ByteArrayInputStream,就是二进制数据流
由于数据库区分date、time、datetime类型,但是Java中一般都使用java.util.Date类型。因此
为了保证数据类型的正确,需要手动指定日期类型,date,time,datetime对应JDBC类型分别为DATE
,TIME,TIMESTAMP。
分析:BLOB那个没看懂,但是date、time、datetime看懂了点,就是说你定义类型时,如果
用了Date类型定义变量,则你插入的时候,最好用jdbcType属性说明一下你插入的究竟是数据
库中的哪种类型。
数据库中的datetime类型可以储存date和timestamp类型这两种类型的值,但是不能存储time类型
的时间。
-->
<insert id="insert">
INSERT INTO sys_user
(id,user_name,user_password,user_email,user_info,head_img,create_time)
VALUES
(#{id},#{userName},#{userPassword},#{userEmail},#{userInfo},#{headImg,jdbcType=BLOB},#{createTime,jdbcType=TIMESTAMP})
</insert>
2.4.2 使用JDBC方式返回主键自增的值
1.接口类中增加的方法:
int insert2(SysUser sysUser);
2.映射文件增加的代码:
<insert id="insert2" useGeneratedKeys="true" keyProperty="id">
INSERT INTO sys_user
(id,user_name,user_password,user_email,
user_info,head_img,create_time)
VALUES
(#{id},#{userName},#{userPassword},#{userEmail},
#{userInfo},#{headImg,jdbcType=BLOB},#{createTime,jdbcType=TIMESTAMP})
</insert>
2.4.3 使用selectKey返回主键的值
1.接口类中增加的方法:
int insert3(SysUser sysUser);
2.映射文件增加的代码:
<insert id="insert3">
INSERT INTO sys_user
(id,user_name,user_password,user_email,
user_info,head_img,create_time)
VALUES
(#{id},#{userName},#{userPassword},#{userEmail},
#{userInfo},#{headImg,jdbcType=BLOB},#{createTime,jdbcType=TIMESTAMP})
<!--
selectKey标签的属性:
keyColumn:
keyProperty:
resultType:
order:该属性与数据库有关。在MySQl中,为after值
-->
<selectKey keyColumn="id" resultType="long" keyProperty="id" order="AFTER">
SELECT LAST_INSERT_ID()
</selectKey>
</insert>
MyBatis从入门到精通:insert用法的更多相关文章
- MyBatis从入门到精通(二):MyBatis XML方式的基本用法之Select
最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. 明确需求 书中提到的需求是一个基 ...
- MyBatis从入门到精通(四):MyBatis XML方式的基本用法之增删改
最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. insert用法 1.1 简单的 ...
- MyBatis从入门到精通(三):MyBatis XML方式的基本用法之多表查询
最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. 多表查询 上篇博客中,我们示例的 ...
- MyBatis从入门到精通(五):MyBatis 注解方式的基本用法
最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. @Select 注解 1.1 使 ...
- MyBatis从入门到精通(六):MyBatis动态Sql之if标签的用法
最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解如何使用if标签生成动 ...
- MyBatis从入门到精通(七):MyBatis动态Sql之choose,where,set标签的用法
最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解如何使用choose, ...
- MyBatis从入门到精通(八):MyBatis动态Sql之foreach标签的用法
最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 本篇博客主要讲解如何使用foreach ...
- MyBatis从入门到精通(第9章):Spring集成MyBatis(中)
MyBatis从入门到精通(第9章):Spring集成MyBatis(中) 框架(Framework)是整个或部分系统的可重用设计,表现为一组抽象构件及构件实例间交互的方法.应该将应用自身的设计和具体 ...
- MyBatis从入门到精通(第5章):MyBatis代码生成器
jdk1.8.MyBatis3.4.6.MySQL数据库5.6.45.Eclipse Version: 2019-12 M2 (4.14.0) MyBatis从入门到精通(第5章):MyBatis代码 ...
- MyBatis从入门到精通(一):MyBatis入门
最近在读刘增辉老师所著的<MyBatis从入门到精通>一书,很有收获,于是将自己学习的过程以博客形式输出,如有错误,欢迎指正,如帮助到你,不胜荣幸! 1. MyBatis简介 2001 ...
随机推荐
- storm(二)消息的可靠处理
storm 通过 trident保证了对消息提供不同的级别.beast effort,at least once, exactly once. 一个tuple 从spout流出,可能会导致大量的tup ...
- webform的图片防盗链
最近用到域的问题,不是同一主机的请求将不允许请求此页面. 这其实和图片防盗链的本质是一样的. 通过两个属性:由于当时用的aspx视图引擎,所以需要通过HttpContext.Current才能拿到ht ...
- VS2008下QT整合OGRE
环境配置如下:VS2008 QT版本:4.8.1 OGRE版本: 1.7.4 请先配置好QT for vs2008 : 下载QT VS2008的包,然后下个QT VS的插件 版本必须是VS2008 ...
- 虚拟机安装 ubuntu 后,更新源无效,以及无法联网安装软件的问题
问题: 虚拟机安装 ubuntu 后,更新源无效,以及无法联网安装软件: 错误提示: Err http://security.ubuntu.com/ubuntu/ trusty-security/un ...
- 记录一次PHP项目报502的问题
问题描述 最近有台服务器偶尔会报502错误,虽然量不多,每天就几十个,但是也必须得找到原因,避免让小问题变成大问题. 排查过程 502错误的原因,一般是对用户访问请求的响应超时造成的,一开始以为是请求 ...
- 用Golang让自己的电脑自动登录“上网管理”系统
用Golang让自己的电脑自动登录 1.缘起 大天朝的网络一般都是只对某些人开放的.上行下效,同样的措施也作用在我们的教育网上.我想不出来,为什么很多领导的总有这样的恶趣味(如果做的到,他们恨不得监控 ...
- Windows下获取逻辑cpu数量和cpu核数量(用GetLogicalProcessorInformation,从XP3才开始有的API)
代码可在Windows NT下正常运行 具体API说明请参照如下文档: GetLogicalProcessorInformation 点击打开链接 点击打开链接 点击打开链接 typedef BOOL ...
- <iOS小技巧>UIview指定设置控件圆角
一.用法: 众所周知,设置控件的圆角使用layer.cornerRadius属性即可,但是这样设置成的结果是4个边角都是圆角类型. 利用班赛尔曲线画角: //利用班赛尔曲线画角 UIB ...
- 再谈Delphi关机消息拦截 -- 之控制台程序 SetConsoleCtrlHandler(控制台使用回调函数拦截,比较有意思)
这里补充一下第一篇文章中提到的拦截关机消息 Delphi消息拦截:http://blog.csdn.net/cwpoint/archive/2011/04/05/6302314.aspx 下面我再介绍 ...
- DataVeryLite和Nhibernate性能对比
电脑型号:acer 4752g 电脑配置: 代码分享: class Program { static void Main(string[] args) { Debug.Listeners.Add(ne ...