MyBatis笔记(二) 最简单的insert命令
接上一篇随笔。这里没有用到MyBatis最关键的映射器接口,因此只做个简单的insert操作,update和delete同理,就不再赘述了。
直接上代码:
首先是dao包下的UserDAO.java文件:
- package com.alleymeowy.dao;
- import com.alleymeowy.bean.User;
- import com.alleymeowy.util.DBUtil;
- import org.apache.ibatis.session.SqlSession;
- import java.io.IOException;
- import java.util.List;
- public class UserDAO {
- /**
- * 根据id查询一条记录
- * @param id
- * @throws IOException
- */
- public static User selectOne(int id) throws IOException {
- SqlSession sqlSession = null;
- User user;
- try {
- sqlSession = DBUtil.getSqlSession();
- user = sqlSession.selectOne("com.alleymeowy.config.sql.Users.selectOne", id);
- } finally {
- sqlSession.close();
- }
- return user;
- }
- /**
- * 查询多条记录
- * @throws IOException
- */
- public static List<User> selectAll() throws IOException {
- SqlSession sqlSession = null;
- List<User> users;
- try {
- sqlSession = DBUtil.getSqlSession();
- users = sqlSession.selectList("com.alleymeowy.config.sql.Users.selectAll");
- } finally {
- sqlSession.close();
- }
- return users;
- }
- public static void insert(User user) throws IOException {
- SqlSession sqlSession = null;
- try {
- sqlSession = DBUtil.getSqlSession();
- int affectrows = sqlSession.insert("com.alleymeowy.config.sql.Users.insertUser", user);
- System.out.println("affectrows : " + affectrows);
- sqlSession.commit();
- } finally {
- if (sqlSession != null) {
- sqlSession.close();
- }
- }
- }
- public static void main(String[] args) throws IOException {
- // System.out.println(selectOne(1));
- // System.out.println("************");
- // System.out.println(selectAll());
- insert(new User(6, "insertPerson", 100));
- }
- }
这里添加了一个insert方法。
然后是Users.xml文件,这里存放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="com.alleymeowy.config.sql.Users">
- <select id="selectOne" parameterType="int" resultType="com.alleymeowy.bean.User">
- select id, name, age from user where id = #{id}
- </select>
- <select id="selectAll" resultType="com.alleymeowy.bean.User">
- select id, name, age from user
- </select>
- <insert id="insertUser" parameterType="com.alleymeowy.bean.User">
- insert into user(id, name, age) values(#{id}, #{name}, #{age})
- </insert>
- </mapper>
同样也是增加了一条insert语句【很简单吧】。
其他代码如总配置文件,DBUtil工具类等都不需要改动了,这里贴出最后的输出结果:
affectrows为1,改变了数据库中的1行。
完毕。
MyBatis笔记(二) 最简单的insert命令的更多相关文章
- MyBatis笔记二:配置
MyBatis笔记二:配置 1.全局配置 1.properites 这个配置主要是引入我们的 properites 配置文件的: <properties resource="db.pr ...
- Mybatis笔记二:接口式编程
目录 旧方法的弊端 接口式编程 接口式编程的好处 接口式编程的增删改查 旧方法的弊端 在Mybatis笔记一中,我们使用命名空间+id的方式实现了Mybatis的执行,不过这里的命名空间是我们随便写的 ...
- how tomcat works 读书笔记(二)----------一个简单的servlet容器
app1 (建议读者在看本章之前,先看how tomcat works 读书笔记(一)----------一个简单的web服务器 http://blog.csdn.net/dlf123321/arti ...
- MyBatis之二:简单增删改查
这一篇在上一篇的基础上简单讲解如何进行增删改查操作. 一.在mybatis的配置文件conf.xml中注册xml与注解映射 <!-- 注册映射文件 --> <mappers> ...
- Mybatis笔记二
一对一查询 案例:查询所有订单信息,订单信息中显示下单人信息. 注意:因为一个订单信息只会是一个人下的订单,所以从查询订单信息出发关联查询用户信息为一对一查询.如果从用户信息出发查询用户下的订单信息则 ...
- Mybatis笔记二:org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)
错误异常:org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.test.dao.N ...
- mybatis笔记<二> 整合spring
mybatis与spring整合需要添加几个jar包,mybatis-spring, spring-context, spring-jdbc 1. spring ioc只要一个jar包就ok 2. 我 ...
- 吴裕雄--天生自然HADOOP操作实验学习笔记:hdfs简单的shell命令
实验目的 了解bin/hadoop脚本的原理 学会使用fs shell脚本进行基本操作 学习使用hadoop shell进行简单的统计计算 实验原理 1.hadoop的shell脚本 当hadoop集 ...
- MyBatis 学习二之简单练习巩固
1.新建一个maven项目并在pom.xml中添加依赖 2.项目架构 配置文件:SqlMapConfig.xml <?xml version="1.0" encoding ...
随机推荐
- 洛谷P3835 【模板】可持久化平衡树
题目背景 本题为题目 普通平衡树 的可持久化加强版. 数据已经经过强化 感谢@Kelin 提供的一组hack数据 题目描述 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作( ...
- PAT甲级1078 Hashing【hash】
题目:https://pintia.cn/problem-sets/994805342720868352/problems/994805389634158592 题意: 给定哈希表的大小和n个数,使用 ...
- 邮局 100分代码(dfs+多重剪枝)
蓝桥杯真题-邮局 #include<iostream> #include<algorithm> #include<set> #include<string&g ...
- CS(计算机科学)知识体
附 录 A CS( 计算机科学)知识体 计算教程 2001 报告的这篇附录定义了计算机科学本科教学计划中可能讲授的知识领域.该分类方案的依据及其历史.结构和应用的其 ...
- 自动化脚本测试,postman使用沉淀
// 服务器地址 var server = 'XXXXXXXXXXXX'; //秘钥Key var secretKey = 'XXXXXXXXXXXX'; //获取当前时间 function crea ...
- html实现调用jar包
整体思路:html引用URL protocol-本地注册表key,key对应某一c#写的exe可执行文件,由exe可执行文件调用cmd,cmd执行jar包. 1.添加注册表: Windows Regi ...
- 2018-2019-2 20165336 《网络对抗技术》 Exp6 信息搜集与漏洞扫描
2018-2019-2 20165336 <网络对抗技术> Exp6 信息搜集与漏洞扫描 一.原理与实践说明 1.实践内容 本实践的目标是掌握信息搜集的最基础技能.具体有: 各种搜索技巧的 ...
- GMT\UTC YYYY-MM-DDTHH:mm:ss.sssZ、YYYY-MM-DDTHH:mm:ss.sss+8:00意义及与北京时间转换
UTC: Universal Time Coordinated 协调世界时,又称世界标准时间. GMT: Greenwich Mean Time 格林尼治平均时. 格林尼治标准时间的正午是指当太阳横穿 ...
- 理解 JavaScript 中的 this
前言 理解this是我们要深入理解 JavaScript 中必不可少的一个步骤,同时只有理解了 this,你才能更加清晰地写出与自己预期一致的 JavaScript 代码. 本文是这系列的第三篇,往期 ...
- JS生成当前月份包括最近12个月内的月份
var last_year_month = function() { var result = []; for(var i = 0; i < 12; i++) { var d = new Dat ...