Mybatis的CRUD

1.修改配置文件Category.xml,提供CRUD对应的sql语句。

 <?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="mybatis.pojo">
<insert id="addCategory" parameterType="Category">
insert into category ( name ) values (#{name})
</insert> <delete id="deleteCategory" parameterType="Category">
delete from category where id= #{id}
</delete> <select id="getCategory" parameterType="_int" resultType="Category">
select * from category where id= #{id}
</select> <update id="updateCategory" parameterType="Category">
update category set name=#{name} where id=#{id}
</update>
<select id="listCategory" resultType="Category">
select * from category
</select>
</mapper>

2.增加(C)

向数据库中插入10条数据

     private void Myinset() throws IOException {
create();
for (int i = 0; i < 10; i++) {
Category category = new Category();
category.setName("xiaomi" + i);
session.insert("addCategory", category);
}
listAll(session);
close();
}

通过session.insert调用addCategory对应的SQL语句,addCategory对应的插入sql语句,#{name}会自动获取category对象的name属性值

 <insert id="addCategory" parameterType="Category">
insert into category ( name ) values (#{name})
</insert>

3.删除(D)

删除id=6的对象

     private void Mydelete() throws IOException {
create();
Category category = new Category();
category.setId(6);
session.delete("deleteCategory", category);
listAll(session);
close();
}

通过session.delete调用deleteCategory对应的SQL语句,deleteCategory对应删除sql语句,#{id}会获取category对象的id。

 <delete id="deleteCategory" parameterType="Category">
delete from category where id= #{id}
</delete>

4.更新(U)

通过session.update进行修改。updateCategory对应的sql语句,#{name}和#{id}获取category对象的name和id。

     <update id="updateCategory" parameterType="Category">
update category set name=#{name} where id=#{id}
</update>
     private void Myupdate() throws IOException {
create();
Category category = session.selectOne("getCategory", 3);
category.setName("修改了的Category名字");
session.update("updateCategory", category);
listAll(session); }

5.查询(R)

<1>查询所有

     private void Allquery() throws IOException {
create();
listAll(session);
close();
}

对应的sql查询语句:

     <select id="listCategory" resultType="Category">
select * from category
</select>

<2>根据id查询

通过session.selectOne获取id=3的记录,Category category= session.selectOne("getCategory",3),getCategory对应的sql语句:

     <select id="getCategory" parameterType="_int" resultType="Category">
select * from category where id= #{id}
</select>
     private void Myquery() throws IOException {
create();
Category category = session.selectOne("getCategory", 3);
System.out.println(category.getName());
close();
}

testCRUD.java

 package mybatis.test;

 import java.io.IOException;
import java.io.InputStream;
import java.util.List; import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; import mybatis.pojo.Category; public class testCRUD { private SqlSession session;
private InputStream inputStream;
private SqlSessionFactory sqlSessionFactory; public testCRUD() throws IOException {
// TODO Auto-generated constructor stub
String resource = "mybatis-config.xml";
this.inputStream = org.apache.ibatis.io.Resources.getResourceAsStream(resource);
this.sqlSessionFactory = new SqlSessionFactoryBuilder().build(this.inputStream);
} public void create() throws IOException {
session = sqlSessionFactory.openSession();
} public void close() {
session.commit();
session.close();
} // 1.增加
private void Myinset() throws IOException {
create();
for (int i = 0; i < 10; i++) {
Category category = new Category();
category.setName("xiaomi" + i);
session.insert("addCategory", category);
}
listAll(session);
close();
} // 2.删除
private void Mydelete() throws IOException {
create();
Category category = new Category();
category.setId(6);
session.delete("deleteCategory", category);
listAll(session);
close();
} // 3.查询
private void Myquery() throws IOException {
create();
Category category = session.selectOne("getCategory", 3);
System.out.println(category.getName());
close();
} // 4.更新
private void Myupdate() throws IOException {
create();
Category category = session.selectOne("getCategory", 3);
category.setName("修改了的Category名字");
session.update("updateCategory", category);
listAll(session); } // 5.查询所有
private void Allquery() throws IOException {
create();
listAll(session);
close();
} // 列出所有的对象名字
private void listAll(SqlSession session) {
List<Category> cs = session.selectList("listCategory");
for (Category c : cs) {
System.out.println(c.getName());
}
} public static void main(String[] args) throws IOException {
testCRUD testCRUD = new testCRUD();
// testCRUD.Myinset();
// testCRUD.Mydelete();
// testCRUD.Myquery();
testCRUD.Myupdate();
// testCRUD.Allquery();
}
}

笔记51 Mybatis快速入门(二)的更多相关文章

  1. MyBatis学习笔记(一)——MyBatis快速入门

    转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4261895.html 一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优 ...

  2. 笔记56 Mybatis快速入门(七)

    相关概念介绍(二) 6.一级缓存 <1>在一个session里查询相同id的数据 package mybatis.annotation; import java.io.IOExceptio ...

  3. 笔记50 Mybatis快速入门(一)

    一.Mybatis简介 MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis ...

  4. 笔记52 Mybatis快速入门(三)

    一.更多查询 1.模糊查询 修改Category.xml,提供listCategoryByName查询语句select * from category where name like concat(' ...

  5. mybatis快速入门(二)

    这次接着上次写增删改查吧. 现将上节的方法改造一下,改造测试类. package cn.my.test; import java.io.IOException; import java.io.Inpu ...

  6. 笔记55 Mybatis快速入门(六)

    相关概念介绍(一) 1.日志 有时候需要打印日志,知道mybatis执行了什么样的SQL语句,以便进行调试.这时,就需要开启日志,而mybatis自身是没有带日志的,使用的都是第三方日志,这里介绍如何 ...

  7. 笔记54 Mybatis快速入门(五)

    Mybatis中注解的使用 1.XML方式的CRUD 新增加接口CategoryMapper ,并在接口中声明的方法上,加上注解对比配置文件Category.xml,其实就是把SQL语句从XML挪到了 ...

  8. 笔记53 Mybatis快速入门(四)

    动态SQL 1.if 假设需要对Product执行两条sql语句,一个是查询所有,一个是根据名称模糊查询.那么按照现在的方式,必须提供两条sql语句:listProduct和listProductBy ...

  9. MyBatis学习总结(一)——MyBatis快速入门

    一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...

随机推荐

  1. ES5新增方法(数组,字符串,对象)

    一.数组方法 迭代(遍历)方法:forEach().map().filter().some().every(): 1. array. forEach(function(value,index,arr) ...

  2. 杭电多校第六场-J-Ridiculous Netizens

    Problem Description Mr. Bread has a tree T with n vertices, labeled by 1,2,…,n. Each vertex of the t ...

  3. Tomcat 配置访问限制:访问白名单和访问黑名单

    最近公司的阿里云服务器上配置的 Tomcat 服务器运行 java的环境,但是通过观察 Tomcat 这几天的日志发现,有很多莫名其妙的 IP 访问主机下莫名其妙的地址,如:/80./testprox ...

  4. jstl jsp long to date

    jsp 页面中使用jstl el 将long转换为时间类型,并格式化输出 <%@ taglib uri="http://java.sun.com/jsp/jstl/core" ...

  5. JavaIO流之File操作

    IO流: File: File(文件/文件夹地址)构造函数: public File(String path); public File(String parentPath, String child ...

  6. Python爬虫实战—— Request对象之header伪装策略

    在header当中,我们经常会添加两个参数--cookie 和 User-Agent,来模拟浏览器登录,以此提高绕过后台服务器反爬策略的可能性. User-Agent获取 User-Agent可通过随 ...

  7. vue 表格 多选 换页保存前一页的状态

    表格多选 点击下一页,上一页的状态没消失. 在表格 添加 row-key="id" 在表格行里添加 reserve-selection

  8. swiper轮播箭头垂直居中

    取消懒加载 for (var i in $('.p01-s9 .lazyload')) { $('.p01-s9 .lazyload').eq(i).attr('src',$('.p01-s9 .la ...

  9. js设计模式——9.装饰器模式

    装饰一个圣诞树 // 装饰器模式,让其依次执行 var tree = {}; tree.decorate = function() { console.log('Make sure the tree ...

  10. [bzoj3033]太鼓达人 题解(搜索)

    Description 七夕祭上,Vani牵着cl的手,在明亮的灯光和欢乐的气氛中愉快地穿行.这时,在前面忽然出现了一台太鼓达人机台,而在机台前坐着的是刚刚被精英队伍成员XLk.Poet_shy和ly ...