mybitis学习笔记
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.fxr.mapper.StudentMapper">
<!-- 中间,对象的属性和结果集的字段的对应的关系 -->
<resultMap type="com.fxr.model.Student" id="studentRM">
<!-- 主键的映射 -->
<id property="id" column="ID"/>
<!-- 普通字段的映射 property指的是实体的属性;column结果集中的字段的名称 -->
<result property="name" column="NAME"/>
<result property="age" column="AGE"/>
<result property="sex" column="SEX"/>
<result property="birthday" column="BIRTHDAY"/>
<!-- 对象关联 -->
</resultMap>
<!-- 查询,注意Mybatis中如果有填写集合的类型,只填写集合中元素的类型 -->
<select id="find" resultMap="studentRM">
select ID,NAME,AGE,SEX,BIRTHDAY from student
</select>
<!-- 查询一个按照id查询 -->
<select id="get" parameterType="int" resultType="com.fxr.model.Student">
select * from student where id = #{id}
</select>
<!-- 添加 -->
<insert id="insert" parameterType="com.fxr.model.Student">
insert into student
(id,name,age,sex,birthday)values
(#{id},#{name},#{age},#{sex},#{birthday})
</insert>
<!-- 修改 -->
<update id="update" parameterType="com.fxr.model.Student">
update student set name=#{name},age=#{age},birthday = #{birthday},sex=#{sex}
where id = #{id}
</update>
<!-- 删除一条 -->
<delete id="deleteById" parameterType="int">
delete from student where id=#{id}
</delete>
<!-- 删除多条整型数组 -->
<delete id="deleteArray" parameterType="int">
delete from student where id in
<foreach collection="array" item="id" open="(" close=")" separator=",">
#{id}
</foreach>
</delete>
<!-- 删除多条list集合 -->
<delete id="deleteList" parameterType="int">
delete from student where id in
<foreach collection="list" item="id" open="(" close=")" separator=",">
#{id}
</foreach>
</delete>
<!-- 删除多条,map,ids为map中的值 -->
<delete id="deleteMap" parameterType="map">
delete from student
where id in
<foreach collection="ids" item="id" open="(" close=")" separator=",">
#{id}
</foreach>
</delete>
</mapper>
public class Student {
private Integer id;
private String name;
private String sex;
private Integer age;
private Date birthday;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public Date getBirthday() {
return birthday;
}
public void setBirthday(Date birthday) {
this.birthday = birthday;
}
@Override
public String toString() {
return "Student [id=" + id + ", name=" + name + ", sex=" + sex
+ ", age=" + age + ", birthday=" + birthday + "]";
}
}
public class TestMyBatis {
private SqlSessionFactory factory;
@Before
public void init() throws IOException{
String resource = "mybatis-config.xml";
InputStream is = Resources.getResourceAsStream(resource);
factory = new SqlSessionFactoryBuilder().build(is);
}
//@Test
// public void testInsert(){
// SqlSession session = factory.openSession();
// Student s = new Student();
// s.setAge(10);
// s.setBirthday(new Date());
//
// s.setName("樊西蕊");
// s.setSex("男");
//
// session.insert("com.fxr.mapper.StudentMapper.insert", s);
// session.commit();//提交事务
// System.out.println("insert finished.");
//
// }
@Test
public void testFindAll(){
SqlSession session = factory.openSession();
//如何访问mapper中的方法啊,规则就是命名空间+.+id
List<Student> personList = session.selectList("com.fxr.mapper.StudentMapper.find");
System.out.println(personList.size());
for (Student s:personList) {
System.out.println(s.toString());
}
}
// @Test
// public void testGet(){
// SqlSession session = factory.openSession();
// Student s = session.selectOne("com.fxr.mapper.StudentMapper.get","1");
// System.out.println("id:"+s.getId()+s.toString());
// }
// @Test
// public void testUpdate(){
// SqlSession session = factory.openSession();
// Student s = new Student();
// s.setId(1);
// s.setName("张三");
// session.update("com.fxr.mapper.StudentMapper.update",s);
// session.commit();
// }
//删除一条数据
// @Test
// public void testDeleteById(){
// SqlSession session = factory.openSession();
// session.delete("com.fxr.mapper.StudentMapper.deleteById",4);
// session.commit();
// }
//删除多条数据
// @Test
// public void testDeleteByArray(){
// SqlSession session = factory.openSession();
// int [] ids = {5,7};
// session.delete("com.fxr.mapper.StudentMapper.deleteArray",ids);
// session.commit();
// }
//删除多条-List
// @Test
// public void testDeleteList(){
// SqlSession session = factory.openSession();
// List<Integer> list = new ArrayList<Integer>();
// list.add(3);
// list.add(8);
// session.delete("com.fxr.mapper.StudentMapper.deleteList",list);
// session.commit();
//
// }
//删除多条-map
@Test
public void testDeleteMap(){
SqlSession session = factory.openSession();
Map<String,Object> paraMap = new HashMap<String,Object>();
int [] ids = {2,6};
paraMap.put("ids", ids);
session.delete("com.fxr.mapper.StudentMapper.deleteMap",paraMap);
session.commit();
}
}
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 配置数据源,事务 -->
<environments default="test">
<environment id="test">
<!-- 事务:JDBC/MANGED自己管理去 -->
<transactionManager type="JDBC"/>
<!-- 数据源:POOLED/UNPOOLED/JNDI -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mybatisdb?charsetEncoding=utf8"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</dataSource>
</environment>
<environment id="deploy">
<!-- 事务:JDBC/MANAGED-自己管理去 -->
<transactionManager type="JDBC"/>
<!-- 数据源:POOLED/UNPOOLED/JNDI -->
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mybatisdb?charsetEncoding=utf8"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</dataSource>
</environment>
</environments>
<!-- 映射文件mapper -->
<mappers>
<mapper resource="com/fxr/mapper/StudentMapper.xml"/>
</mappers>
</configuration>
/firstMyBatis/lib/asm-3.3.1.jar
/firstMyBatis/lib/cglib-2.2.2.jar
/firstMyBatis/lib/commons-logging-1.1.1.jar
/firstMyBatis/lib/javassist-3.17.1-GA.jar
/firstMyBatis/lib/log4j-1.2.17.jar
/firstMyBatis/lib/mybatis-3.2.2.jar
/firstMyBatis/lib/mysql-connector-java-5.1.26.jar
/firstMyBatis/lib/slf4j-api-1.7.5.jar
/firstMyBatis/lib/slf4j-log4j12-1.7.5.jar
mybitis学习笔记的更多相关文章
- Mybatis学习笔记二
本篇内容,紧接上一篇内容Mybatis学习笔记一 输入映射和输出映射 传递简单类型和pojo类型上篇已介绍过,下面介绍一下包装类型. 传递pojo包装对象 开发中通过可以使用pojo传递查询条件.查询 ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- PHP-自定义模板-学习笔记
1. 开始 这几天,看了李炎恢老师的<PHP第二季度视频>中的“章节7:创建TPL自定义模板”,做一个学习笔记,通过绘制架构图.UML类图和思维导图,来对加深理解. 2. 整体架构图 ...
- PHP-会员登录与注册例子解析-学习笔记
1.开始 最近开始学习李炎恢老师的<PHP第二季度视频>中的“章节5:使用OOP注册会员”,做一个学习笔记,通过绘制基本页面流程和UML类图,来对加深理解. 2.基本页面流程 3.通过UM ...
- 2014年暑假c#学习笔记目录
2014年暑假c#学习笔记 一.C#编程基础 1. c#编程基础之枚举 2. c#编程基础之函数可变参数 3. c#编程基础之字符串基础 4. c#编程基础之字符串函数 5.c#编程基础之ref.ou ...
- JAVA GUI编程学习笔记目录
2014年暑假JAVA GUI编程学习笔记目录 1.JAVA之GUI编程概述 2.JAVA之GUI编程布局 3.JAVA之GUI编程Frame窗口 4.JAVA之GUI编程事件监听机制 5.JAVA之 ...
- seaJs学习笔记2 – seaJs组建库的使用
原文地址:seaJs学习笔记2 – seaJs组建库的使用 我觉得学习新东西并不是会使用它就够了的,会使用仅仅代表你看懂了,理解了,二不代表你深入了,彻悟了它的精髓. 所以不断的学习将是源源不断. 最 ...
- CSS学习笔记
CSS学习笔记 2016年12月15日整理 CSS基础 Chapter1 在console输入escape("宋体") ENTER 就会出现unicode编码 显示"%u ...
- HTML学习笔记
HTML学习笔记 2016年12月15日整理 Chapter1 URL(scheme://host.domain:port/path/filename) scheme: 定义因特网服务的类型,常见的为 ...
随机推荐
- Elasticsearch学习之查询去重
1. 实现查询去重.分页,例如:实现依据qid去重,createTime排序,命令行为: GET /nb_luban_answer/_search { "query": { &qu ...
- 小米2s线刷出现remote: partition table doesn't exist
=================问题============ 小米2s线刷出现remote: partition table doesn't exist =================解决方案= ...
- mysql客户端工具
MySQL 数据库不仅提供了数据库的服务器端应用程序,同时还提供了大量的客户端工具程序,如 mysql,mysqladmin,mysqldump 等等,都是大家所熟悉的.虽然有些人对这些工具的功能都已 ...
- C语言位操作--判断整数的符号
关于衡量计算操作的方法: 当为算法统计操作的数量的时候,所有的C运算符被认为是一样的操作.中间过程不被写入随机存储器(RAM)而不被计算,当然,这种操作数的计算方法,只是作为那些接近机器指令和CPU运 ...
- 【CF819D】Mister B and Astronomers EXGCD
[CF819D]Mister B and Astronomers 题意:小鼠Jack想当太空人(哦不,太空鼠)!为此,它在夜晚带领一堆小朋友一起来到户外看星星.一共有 $n$ 只小鼠,这些小鼠围成一 ...
- vue--自定义指令进行验证(1)
实例代码: <template> <div id="app" class="app"> <h3>{{msg}}</h3 ...
- 极大既然估计和高斯分布推导最小二乘、LASSO、Ridge回归
最小二乘法可以从Cost/Loss function角度去想,这是统计(机器)学习里面一个重要概念,一般建立模型就是让loss function最小,而最小二乘法可以认为是 loss function ...
- Django的quarySet
models.py 代码 from django.db import models # Create your models here. class Author(models.Model): nam ...
- od --http://blog.csdn.net/hgy413/article/details/7711925
http://blog.csdn.net/hgy413/article/details/7711925
- ArcGIS Server 内存占用相关
发布服务个数是否有上限? 不仅是服务个数,每个服务的实例数设置非常影响机器内存与CPU的占用. 发布服务时,如果服务不经常被访问,可以将最低实例数设置为0,避免后台长期占用内存. Server需要的机 ...