1.新建项目,添加mybatis和mysql的jar包

2.在mysql中新建表user[id,name,age]

CREATE TABLE `users` (
`id` int(11) NOT NULL auto_increment,
`NAME` varchar(50) default NULL,
`age` int(11) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8

3.新建User类,与db的表对应

public class User {

    public User() {
}
public User(int id, String name, int age) {
super();
this.id = id;
this.name = name;
this.age = age;
}
private int id;
private String name;
private int age;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return "User [id=" + id + ", name=" + name + ", age=" + age + "]";
} }

4.在src目录下面新建mybatis的配置文件conf.xml

<?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>
<!--
development:开发模式
work:工作模式
-->
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<property name="driver" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/mybatis?autoReconnect=true&amp;useUnicode=true&amp;characterEncoding=utf8" />
<property name="username" value="root" />
<property name="password" value="root" />
</dataSource>
</environment>
</environments> </configuration>

5.新建userMapper.xml,添加数据库操作语句

<?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的标签,在此要在Window-Preference-Xml Catalog中配置mybatis-3-mapper.dtd,
key=-//mybatis.org//DTD Mapper 3.0//EN
-->
<mapper namespace="com.mlxs.mybatis.test.userMapper"> <select id="getUser" parameterType="int" resultType="com.mlxs.mybatis.test1.User">
select * from users where id=#{id}
</select> <!-- 添加,参数是一个user对象 -->
<insert id="addUser" parameterType="com.mlxs.mybatis.test1.User">
insert into users(name,age) values(#{name},#{age})
</insert>
<!-- 更新,参数是一个user对象 -->
<insert id="updateUser" parameterType="com.mlxs.mybatis.test1.User">
update users set name=#{name}, age=#{age} where id=#{id}
</insert>
<!-- 添加,参数是一个user对象 -->
<insert id="deleteUser" parameterType="int">
delete from users where id=#{id}
</insert> <!-- 返回一个list,resultType="包名+类名":必须在类中有个无参的构造函数,不然会报错:
java.lang.NoSuchMethodException: com.mlxs.mybatis.test1.User.<init>()
Caused by: java.lang.NoSuchMethodException: com.mlxs.mybatis.test1.User.<init>()
at java.lang.Class.getConstructor0(Class.java:2706)
at java.lang.Class.getDeclaredConstructor(Class.java:1985)
at org.apache.ibatis.reflection.factory.DefaultObjectFactory.instantiateClass(DefaultObjectFactory.java:57)
-->
<select id="selectAllUsers" resultType="com.mlxs.mybatis.test1.User">
select * from users
</select>
</mapper>

将mapper配置文件添加到mybatis的配置文件conf.xml的mappers标签中:

<!-- 在conf.xml文件中注册Mapper.xml文件和Mapper类 -->
<mappers>
<mapper resource="com/mlxs/mybatis/test1/userMapper.xml" /> </mappers>

6.添加测试类,获取一个user的信息

import java.io.IOException;
import java.io.InputStream;
import java.io.Reader; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class _Test1SelectOne {
public static void main(String[] args) throws IOException {
//加载mybatis的xml文件(同时加载加载关联的映射文件)
//1.使用类加载器加载mybatis的配置文件
// InputStream config = _Test1SelectOne.class.getClassLoader().getResourceAsStream("conf.xml");
//2.使用mybatis的Resources类加载
Reader config = Resources.getResourceAsReader("conf.xml");
//创建sqlSessionFactory
SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(config);
//创建sqlSession,执行mapper.xml中的sql语句
SqlSession sqlSession = sessionFactory.openSession();
//执行映射文件中的sql(namespace + select的id)
String sql = "com.mlxs.mybatis.test.userMapper.getUser";
User user = sqlSession.selectOne(sql, "1");//查询id=1
//关闭session
sqlSession.close();
System.out.println(user);
}
}

7.结果

User [id=1, name=Tom, age=12]

8.测试 增删改查,导入junit包,添加测试类

import java.util.List;

import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.junit.Test; import com.mlxs.mybatis.util.MyBatisUtil; public class _Test2UserCrud { @Test
public void addUser(){
SqlSessionFactory sessionFactory = MyBatisUtil.getSessionFactory();
SqlSession sqlSession = sessionFactory.openSession();
String statement = "com.mlxs.mybatis.test.userMapper.addUser";
int count = sqlSession.insert(statement, new User(0, "add1", 10));
sqlSession.commit();
sqlSession.close();
System.out.println("add count:"+count);
}
@Test
public void updateUser(){
SqlSessionFactory sessionFactory = MyBatisUtil.getSessionFactory();
SqlSession sqlSession = sessionFactory.openSession();
String statement = "com.mlxs.mybatis.test.userMapper.updateUser";
int count = sqlSession.update(statement, new User(3, "update2", 100));
sqlSession.commit();
sqlSession.close();
System.out.println("update count:"+count);
}
@Test
public void delUser(){
SqlSessionFactory sessionFactory = MyBatisUtil.getSessionFactory();
boolean autoCommit = true;//自动提交,不需手动commit
SqlSession sqlSession = sessionFactory.openSession(autoCommit);
String statement = "com.mlxs.mybatis.test.userMapper.deleteUser";
int count = sqlSession.delete(statement, 4);
sqlSession.close();
System.out.println("del count:"+count);
}
@Test
public void selectAll(){
SqlSessionFactory sessionFactory = MyBatisUtil.getSessionFactory();
boolean autoCommit = true;//自动提交,不需手动commit
SqlSession sqlSession = sessionFactory.openSession(autoCommit);
String statement = "com.mlxs.mybatis.test.userMapper.selectAllUsers";
List<User> userList = sqlSession.selectList(statement);
sqlSession.close();
System.out.println(userList);
}
}

2.mybatis入门实例 连接数据库进行查询的更多相关文章

  1. Mybatis入门实例

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

  2. Mybatis入门实例解析

    写在前面:本文全程根据Mybatis官网进行入门讲解.毫无疑问,官方文档是学习这门技术最权威的资料,与此同时我们也知道官方文档对待入门小白基本上不太友好,没有入门demo.开篇就是小白们不懂的内容.有 ...

  3. MyBatis入门实例-包括实体类与数据库字段对应&CLOB字段处理

    1.我的开发环境是 jdk1.7+ecplise+oracle 11g 用到的jar包:mybatis-3.1.1.jar ojdbc6.jar 2.项目整体结构     3.首先配置conf.xml ...

  4. MyBatis入门实例 ——Mapper.xml(zz)

    <?xml version="1.0" encoding="UTF-8" ?>    <!DOCTYPE mapper        PUBL ...

  5. mybatis入门案例分析

    mybatis入门案例分析 一.设计模式分析 public class MybatisTest { public static void main(String[] args) throws Exce ...

  6. mybatis 详解(二)------入门实例(基于XML)

    通过上一小节,mybatis 和 jdbc 的区别:http://www.cnblogs.com/ysocean/p/7271600.html,我们对 mybatis有了一个大致的了解,下面我们通过一 ...

  7. mybatis 详解(三)------入门实例(基于注解)

    1.创建MySQL数据库:mybatisDemo和表:user 详情参考:mybatis 详解(二)------入门实例(基于XML) 一致 2.建立一个Java工程,并导入相应的jar包,具体目录如 ...

  8. mybatis学习一:基于xml与注解配置入门实例与问题

    注:本case参考自:http://www.cnblogs.com/ysocean/p/7277545.html 一:Mybatis的介绍: MyBatis 本是apache的一个开源项目iBatis ...

  9. MyBatis基础入门《八》查询参数传入Map

    MyBatis基础入门<八>查询参数传入Map 描述: 在执行select查询数据的时候,方法传入的参数是java.util.Map类型. 接口方法: xml文件 注意: 书写SQL语句的 ...

随机推荐

  1. Mongodb 笔记09 备份、部署MongoDB

    备份 1. 只有在有信心能在紧急情况下完成迅速部署的情况下,备份才是有用的.所以,无论选择了哪种备份技术,一定要对备份及恢复备份的操作进行练习,知道了然于心. 2. 通常情况下,应对副本集的非主节点( ...

  2. stc89c52开发板遥控器解码 红外线发射 内置 eeprom 存储 串口显示编码

    单片机,大概三年前,就买了一本 <爱上单片机> 最后就学会,用面包板了,编程书上基本没讲. 看原理图,看时序图,看数据手册, 都没讲. 而且书上自带的代码写的很烂. 1,缩近控制不好 2, ...

  3. jenkins+jmeter+ant搭建接口测试平台

    接口测试的重点是检查数据的交换,传递和控制管理过程以及系统间的相互逻辑依赖关系. 接口测试的流程 项目启动后,测试人员要尽早拿到接口测试文档. 开始编写接口测试用例 将接口测试用例部署到持续集成的测试 ...

  4. Verilog HDL基础语法讲解之模块代码基本结构

    Verilog HDL基础语法讲解之模块代码基本结构   本章主要讲解Verilog基础语法的内容,文章以一个最简单的例子"二选一多路器"来引入一个最简单的Verilog设计文件的 ...

  5. centos7重启rsyslog服务|centos7重启syslog服务

    centos7重启rsyslog服务: systemctl restart rsyslog 使用:(killall无效) killall -HUP rsyslog

  6. Oracle 单行函数

    一.什么是函数 任何东西,只要它能接收输入,对输入进行加工并产生输出,它就可以被称为函数. 二.单行函数简介 单行函数只对表中的一行数据进行操作,并且对每一行数据只产生一个输出结果.单行函数可以接受一 ...

  7. HDU 4453:Looploop(Splay各种操作)

    http://acm.hdu.edu.cn/showproblem.php?pid=4453 题意:很多种操作:1.add x,将从光标起的 k2 个数全部加上 x:2.reverse,将从光标起的 ...

  8. HDU 5768:Lucky7(中国剩余定理 + 容斥原理)

    http://acm.hdu.edu.cn/showproblem.php?pid=5768 Lucky7 Problem Description   When ?? was born, seven ...

  9. Asp.net Vnext IValueProvider

    概述 本文已经同步到<Asp.net Vnext 系列教程 >中] IValueProvider 根据ValueProvider获取数据,在对数据进行绑定 代码实现 private cla ...

  10. okhttp封装

    对这玩意并不熟,网上有很多大神封装好的,但是懒得看里面的封装逻辑,索性自己简单做个封装,方便使用,出现bug也好查找: get请求: /** * get请求 * @param url * @param ...