mybatis_SQL映射(1)

时间:2021-09-04 13:26:46

文章摘录自:http://blog.csdn.net/y172158950/article/details/17258377

1. select的映射

  1. <select id="selectPerson" parameterType="int" resultType="hashmap">
  2. select id, name, sex, updateTime from person where id =#{id};
  3. </select>
a) #{id}:创建预编译语句参数,占位符
b) parameterType:参数的类型,int类型
c)resultType:返回的结果集,封装为hashMap
  1. public Map<String, Object> selectPersonById(int id) {
  2. SqlSession session = DbFactory.getInstance().openSession();  //单例SqlSessionFactory工厂
  3. Map<String, Object> m = (Map<String, Object>) session.selectOne("com.yjq.entity.Person.selectPerson", id);
  4. session.commit();
  5. session.close();
  6. return m;
  7. }
  1. //output
  2. {id=4, sex=f, NAME=zql, updateTime=2013-12-10 14:18:11.0, SEX=f, name=zql, ID=4, UPDATETIME=2013-12-10 14:18:11.0}
d) 结果集为啥有大小写的key2份?神奇的mybatis啊。

2. insert,update,delete的映射

  1. <insert id="insertPerson" parameterType="com.yjq.entity.Person" useGeneratedKeys="true" keyProperty="id"> <!-- 将自增主键生成的值回写到对象  -->
  2. insert into person(name, sex, updateTime) values(#{name}, #{sex}, #{updateTime});
  3. </insert>
  4. <delete id="deletePerson" parameterType="int">
  5. delete from person where id=#{id};
  6. </delete>
  7. <update id="updatePerson" parameterType="com.yjq.entity.Person">
  8. update person set name=#{name}, sex=#{sex}, updateTime=#{updateTime} where id=#{id};
  9. </update>
a) parameterType="com.yjq.entity.Person":对象参数,#{name}表示Person对象的name属性。
b) useGeneratedKeys="true" keyProperty="id":只存在于insert命令,写这2个参数会将主键自增长的值回写到传入的参数对象。
  1. public Person insertPerson(Person p) {
  2. SqlSession session = DbFactory.getInstance().openSession();
  3. session.insert("com.yjq.entity.Person.insertPerson", p);
  4. session.commit();
  5. session.close();
  6. return p;
  7. }
  1. PersonDao dao = new PersonDao();
  2. Person p = new Person();
  3. p.setName("zql");
  4. p.setSex("f");
  5. p.setUpdateTime(new Date());
  6. System.out.println("------" + p.getId());
  7. dao.insertPerson(p);
  8. System.out.println(p.getId());
  1. //output(insert前id未赋值,insert后id=7)
  2. ------0
  3. 7
c) 返回值:insert,update,delete方法均返回int参数,表示操作了多少条数据
  1. int result = session.update("com.yjq.entity.Person.updatePerson", p);
d) 假设数据库不支持自增id,mybatis可以生成随机主键
  1. <insert id="insertPerson2" parameterType="com.yjq.entity.Person">
  2. <selectKey keyProperty="id" resultType="int" order="BEFORE">  <!-- 生成随机id数 -->
  3. select CONVERT(RAND()*1000000,SIGNED) a from dual;
  4. </selectKey>
  5. insert into person(id, name, sex, updateTime) values(#{id}, #{name}, #{sex}, #{updateTime});
  6. </insert>

mybatis_SQL映射(1)的更多相关文章

  1. mybatis&lowbar;SQL映射&lpar;4&rpar;鉴别器

    摘录自:http://blog.csdn.net/y172158950/article/details/17505739 鉴别器:有时一个单独的数据库查询也许返回很多不同(但是希望有些关联)数据类型的 ...

  2. mybatis&lowbar;SQL映射&lpar;3&rpar;

    文章摘录自:http://blog.csdn.net/y172158950/article/details/17304645 1. 表关联 a) 嵌套查询(传说中的1+N问题) <resultM ...

  3. mybatis&lowbar;SQL映射&lpar;2&rpar;

    文章摘录自:http://blog.csdn.net/y172158950/article/details/17258377 1. sql的重用:定义一个sql片段,可在任何SQL语句中重用该片段. ...

  4. Hibernatel框架关联映射

    Hibernatel框架关联映射 Hibernate程序执行流程: 1.集合映射 需求:网络购物时,用户购买商品,填写地址 每个用户会有不确定的地址数目,或者只有一个或者有很多.这个时候不能把每条地址 ...

  5. hibernate多对多关联映射

    关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...

  6. Dapper逆天入门~强类型,动态类型,多映射,多返回值,增删改查&plus;存储过程&plus;事物案例演示

    Dapper的牛逼就不扯蛋了,答应群友做个入门Demo的,现有园友需要,那么公开分享一下: 完整Demo:http://pan.baidu.com/s/1i3TcEzj 注 意 事 项:http:// ...

  7. ElasticSearch 5学习&lpar;9&rpar;——映射和分析(string类型废弃)

    在ElasticSearch中,存入文档的内容类似于传统数据每个字段一样,都会有一个指定的属性,为了能够把日期字段处理成日期,把数字字段处理成数字,把字符串字段处理成字符串值,Elasticsearc ...

  8. &period;NET平台开源项目速览&lpar;14&rpar;最快的对象映射组件Tiny Mapper

    好久没有写文章,工作甚忙,但每日还是关注.NET领域的开源项目.五一休息,放松了一下之后,今天就给大家介绍一个轻量级的对象映射工具Tiny Mapper:号称是.NET平台最快的对象映射组件.那就一起 ...

  9. ASP&period;NET Core的路由&lbrack;1&rsqb;:注册URL模式与HttpHandler的映射关系

    ASP.NET Core的路由是通过一个类型为RouterMiddleware的中间件来实现的.如果我们将最终处理HTTP请求的组件称为HttpHandler,那么RouterMiddleware中间 ...

随机推荐

  1. html 页面内锚点定位及跳转方法总结

    第一种方法,也是最简单的方法是锚点用<a>标签,在href属性中写入DIV的id.如下: <!DOCTYPE html><html><head> &lt ...

  2. 编写高效的js&sol;jQuery代码 &colon;rocket&colon;

    讨论jQuery和javascript性能的文章并不罕见.然而,本文我计划总结一些速度方面的技巧和我本人的一些建议,来提升你的jQuery和javascript代码.好的代码会带来速度的提升.快速渲染 ...

  3. 【原创】使用&period;NET Core 1&period;0创建一个Self-Contained控制台应用

    开发机器:win7-x64 .NET Core版本:1.0.0-preview2-003121 Visual Studio Code:1.2.1 至于什么是Self-Contained应用类型以及与P ...

  4. title及alt提示特效

    <html> <head> <title>title及alt提示特效</title> <style type="text/css&quo ...

  5. HOG参数简介及Hog特征维数的计算(转)

    HOG构造函数 CV_WRAP HOGDescriptor() :winSize(64,128), blockSize(16,16), blockStride(8,8),      cellSize( ...

  6. noip2007 树网的核

    P1099 树网的核 112通过 221提交 题目提供者该用户不存在 标签动态规划树形结构2007NOIp提高组 难度提高+/省选- 提交该题 讨论 题解 记录   题目描述 设T=(V, E, W) ...

  7. linux-LINUX试题

    ylbtech-doc:linux-LINUX试题 LINUX试题 1.A,LINUX试题返回顶部 01.{Linux题目}在使用匿名登录ftp时,用户名为(  )? (选择1项) A) login ...

  8. codeblocks 使用指南z

    1.界面风格更改 首先贴怎么普通设置出来,或者改配置文件 这是我的风格 类似于DEV-CPP里面的一个主题,看的很舒服 具体设置如下: Settings-Editor 1.代码当前行高亮 在Gener ...

  9. sql server2012学习笔记

    第1章 SQL安装   1-1 [SQL Server基础]前言 (10:44) 1-2 SQL Server安装 (08:29) 1-3 第一次登陆 SQL Server (02:58) 1-4 [ ...

  10. POJO,JaveBean,VO,DTO

    POJO - POJO(Plain Ordinary Java Object)简单的Java对象,实际就是普通JavaBeans,是为了避免和EJB混淆所创造的简称. 使用POJO名称是为了避免和EJ ...