需要用到的包:(这里只是其中一个版本,其他的百度)

mysql-connector-java-5.1.6-bin

mybatis-3.2.2

先看项目目录:

配置文件mybatisconfig.xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE configuration
  3. PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-config.dtd">
  5. <configuration>
  6. <!-- 用XML映射的时候必须配此项!指定mappers里面的返回值对应的实体类 -->
  7. <!-- <typeAliases>
  8. <typeAlias alias="User" type="com.miquan.mybatis.bean.User"/>
  9. </typeAliases> -->
  10. <!-- JDBC配置 -->
  11. <environments default="development">
  12. <environment id="development">
  13. <transactionManager type="JDBC"/>
  14. <dataSource type="POOLED">  <!--POOLED指的是:已经缓存的,即使用缓存-->
  15. <property name="driver" value="com.mysql.jdbc.Driver"/>
  16. <property name="url" value="jdbc:mysql://localhost:3306/weixinface"/>
  17. <property name="username" value="root"/>
  18. <property name="password" value=""/>
  19. </dataSource>
  20. </environment>
  21. </environments>
  22. <!-- mappers,每个实体类对应着一个xml -->
  23. <mappers>
  24. <mapper resource="com/miquan/mybatis/bean/User.xml"/>
  25. </mappers>
  26. </configuration>

实体类User.java:

  1. package com.miquan.mybatis.bean;
  2. public class User {
  3. private int id;
  4. private String userName;
  5. private String password;
  6. public User(int id, String userName, String password) {
  7. super();
  8. this.id = id;
  9. this.userName = userName;
  10. this.password = password;
  11. }
  12. public int getId() {
  13. return id;
  14. }
  15. public void setId(int id) {
  16. this.id = id;
  17. }
  18. public String getUserName() {
  19. return userName;
  20. }
  21. public void setUserName(String userName) {
  22. this.userName = userName;
  23. }
  24. public String getPassword() {
  25. return password;
  26. }
  27. public void setPassword(String password) {
  28. this.password = password;
  29. }
  30. }

User.xml:

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!DOCTYPE mapper
  3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <!-- namespace对应着接口类 -->
  6. <mapper namespace="com.miquan.mybatis.inter.IUserOperation">
  7. <!-- <select id="selectById" parameterType="int" resultType="User">
  8. select * from User where id = #{id}
  9. </select> -->
  10. </mapper>

IUserOperation.java:

  1. package com.miquan.mybatis.inter;
  2. import java.util.List;
  3. import org.apache.ibatis.annotations.Delete;
  4. import org.apache.ibatis.annotations.Insert;
  5. import org.apache.ibatis.annotations.Select;
  6. import org.apache.ibatis.annotations.Update;
  7. import com.miquan.mybatis.bean.User;
  8. public interface IUserOperation {
  9. @Select("select * from User where id = #{id}")
  10. public User selectById(int id);
  11. @Select("select * from User where userName = #{userName}")
  12. public List<User> selectUsers(String userName);
  13. @Insert("insert into User values(null, #{userName}, #{password})")
  14. public boolean addUser(User user);
  15. @Delete("delete from User where id = #{id}")
  16. public boolean delUser(int id);
  17. @Update("update User "
  18. + "set userName = #{userName}, "
  19. + "password = #{password} "
  20. + "where id = #{id}")
  21. public boolean updateUser(User user);
  22. }

注意:此处接口不支持多态。

(不知道为什么,用着就是不可以。。。方法名不能一样)

最后进行测试:Test.java:

  1. package com.miquan.mybatis.test;
  2. import java.io.InputStream;
  3. import java.util.List;
  4. import org.apache.ibatis.io.Resources;
  5. import org.apache.ibatis.session.SqlSession;
  6. import org.apache.ibatis.session.SqlSessionFactory;
  7. import org.apache.ibatis.session.SqlSessionFactoryBuilder;
  8. import com.miquan.mybatis.bean.User;
  9. import com.miquan.mybatis.inter.IUserOperation;
  10. public class Test {
  11. static SqlSession session;
  12. public static void main(String[] args) {
  13. try {
  14. //获取session
  15. InputStream is = Resources.getResourceAsStream("mybatisconfig.xml");
  16. SqlSessionFactory sqlSessionFactory =
  17. new SqlSessionFactoryBuilder().build(is);
  18. session = sqlSessionFactory.openSession();
  19. //XML配置对应用法
  20. //          User user = session.selectOne("com.miquan.mybatis.bean.UserDB.selectById", 1);
  21. //          System.out.println(user.toString());
  22. //接口调用法
  23. //////注意:insert、delete和update方法调用之后必须commit才能真正的改变数据
  24. IUserOperation userOperation = session.getMapper(IUserOperation.class);
  25. //查
  26. //          User user = userOperation.selectById(1);
  27. //          System.out.println(user.toString());
  28. //查找List
  29. //          List<User> users = userOperation.selectUsers("miquan");
  30. //          System.out.println(users.size());
  31. //增
  32. //          User user = new User();
  33. //          user.setUserName("zhiquan");
  34. //          user.setPassword("999");
  35. //          userOperation.addUser(user);
  36. //          session.commit();
  37. //删
  38. //          userOperation.delUser(7);
  39. //          session.commit();
  40. //改
  41. User user = new User(8, "qiantu", "shaxppp");
  42. userOperation.updateUser(user);
  43. session.commit();
  44. } catch (Exception e) {
  45. e.printStackTrace();
  46. } finally {
  47. try {
  48. session.close();
  49. } catch (Exception e) {
  50. e.printStackTrace();
  51. }
  52. }
  53. }
  54. }

简单的增删查改可以实现了。

[转]mybatis 的简单使用的更多相关文章

  1. Mybatis框架简单使用

    Mybatis框架简单使用 环境搭建 新建一个JavaWeb项目,在web\WEB-INF\创建lib文件,并且在其下添加Mybatis的核心包以及依赖包,以及Mysql驱动包,junit4测试包等. ...

  2. MyBatis(1)-简单入门

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

  3. MyBatis 使用简单的 XML或注解用于配置和原始映射

    MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis .My ...

  4. 单独使用MyBatis的简单示例

    单独使用MyBatis的简单示例:mybaties-config.xml:MyBatis配置文件 <?xml version="1.0" encoding="UTF ...

  5. Mybatis的简单增删改查

    刚开始学习Mybatis可以先看下官方文档,MyBatis是支持定制化SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis避免了几乎所有的JDBC代码和手工设置参数以及抽取结果集.MyBat ...

  6. Mybatis实现简单的CRUD(增删改查)原理及实例分析

    Mybatis实现简单的CRUD(增删改查) 用到的数据库: CREATE DATABASE `mybatis`; USE `mybatis`; DROP TABLE IF EXISTS `user` ...

  7. Mybatis实现简单增删改查

    Mybatis的简单应用 学习内容: 需求 环境准备 代码 总结: 学习内容: 需求 使用Mybatis实现简单增删改查(以下是在IDEA中实现的,其他开发工具中,代码一样) jar 包下载:http ...

  8. MyBatis学习--简单的增删改查

    jdbc程序 在学习MyBatis的时候先简单了解下JDBC编程的方式,我们以一个简单的查询为例,使用JDBC编程,如下: Public static void main(String[] args) ...

  9. Mybatis的简单示例

    首先新建一个JavaWeb项目并导入mybatis依赖的jar包,同时Mybatis是对数据库的操作所以我们需要在数据库中新建一个表user用来演示. 新建完表之后我们还需要建立相对应的实体类User ...

  10. MyBatis的简单操作

    这里将的是简单的增.删.改.查等基本操作 首先创建java项目,导入相应的依赖包,这里可以参考上一篇博客 1.添加数据 在jike.book.pojo包中,新建java类 JiKeUser.java: ...

随机推荐

  1. C++之编译器与链接器工作原理

    原文来自:http://blog.sina.com.cn/s/blog_5f8817250100i3oz.html 这里并没不是讨论大学课程中所学的<编译原理>,只是写一些我自己对C++编 ...

  2. php快速入门总结

    因为本人已经接触了C和C++两年多了,虽然真正用它们的机会很少,但是基本的语法还是相对熟悉的.半年前的课程设计用了PHP,所以当初我也只是现学先用, 学得很粗糙,现在,跟一个同学合作搞一个比赛的项目, ...

  3. HDU 5129 Yong Zheng's Death

    题目链接:HDU-5129 题目大意为给一堆字符串,问由任意两个字符串的前缀子串(注意断句)能组成多少种不同的字符串. 思路是先用总方案数减去重复的方案数. 考虑对于一个字符串S,如图,假设S1,S2 ...

  4. sqlserver2008 死锁解决方法及性能优化方法

    sqlserver2008 死锁解决方法及性能优化方法 原文: http://blog.csdn.net/kuui_chiu/article/details/48621939 十步优化SQL Serv ...

  5. django渲染模板时跟vue使用的{{ }}冲突解决方法

    var vm = new Vue({ el: '#app', // 分割符: 修改vue中显示数据的语法, 防止与django冲突 delimiters: ['[[', ']]'], data: { ...

  6. 7:django 中间件

    中间件 中间件是一个连接django请求/相应处理的框架,是一个轻量级的低层次的全局影响django输入输出的系统插件. 每一个中间件组件负责一些特定的功能,这里我们我们只看一下如何激活使用系统自带的 ...

  7. MAC Pro 2017款 无线上网慢

    MAC Pro 2017款 在无线路由器和MAC相隔一个房间,上网很慢,怀疑是无线路由器有问题,但其他几台老款MAC和PC上网正常.后来将蓝牙关掉,上网就很快了.

  8. 从Java Future到Guava ListenableFuture实现异步调用

    原文地址: http://blog.csdn.net/pistolove/article/details/51232004 Java Future     通过Executors可以创建不同类似的线程 ...

  9. AC日记——国王游戏 洛谷 P1080

    国王游戏 思路: 贪心+高精: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 1005 struct Dat ...

  10. 处理form表单提交后返回值的处理办法【html5】

    同事朋友ajax,最近在弄公司业务电话机,自主搭建,买的设备. 其中最主要功能是前端发起呼叫,通过浏览器触发设备进行呼叫功能,走后台呼叫还不行. 需求是这样的: 前端给设备ip发送特定的一段xml信息 ...