[转]mybatis 的简单使用
需要用到的包:(这里只是其中一个版本,其他的百度)
mysql-connector-java-5.1.6-bin
先看项目目录:
配置文件mybatisconfig.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>
- <!-- 用XML映射的时候必须配此项!指定mappers里面的返回值对应的实体类 -->
- <!-- <typeAliases>
- <typeAlias alias="User" type="com.miquan.mybatis.bean.User"/>
- </typeAliases> -->
- <!-- JDBC配置 -->
- <environments default="development">
- <environment id="development">
- <transactionManager type="JDBC"/>
- <dataSource type="POOLED"> <!--POOLED指的是:已经缓存的,即使用缓存-->
- <property name="driver" value="com.mysql.jdbc.Driver"/>
- <property name="url" value="jdbc:mysql://localhost:3306/weixinface"/>
- <property name="username" value="root"/>
- <property name="password" value=""/>
- </dataSource>
- </environment>
- </environments>
- <!-- mappers,每个实体类对应着一个xml -->
- <mappers>
- <mapper resource="com/miquan/mybatis/bean/User.xml"/>
- </mappers>
- </configuration>
实体类User.java:
- package com.miquan.mybatis.bean;
- public class User {
- private int id;
- private String userName;
- private String password;
- public User(int id, String userName, String password) {
- super();
- this.id = id;
- this.userName = userName;
- this.password = password;
- }
- public int getId() {
- return id;
- }
- public void setId(int id) {
- this.id = id;
- }
- public String getUserName() {
- return userName;
- }
- public void setUserName(String userName) {
- this.userName = userName;
- }
- public String getPassword() {
- return password;
- }
- public void setPassword(String password) {
- this.password = password;
- }
- }
User.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">
- <!-- namespace对应着接口类 -->
- <mapper namespace="com.miquan.mybatis.inter.IUserOperation">
- <!-- <select id="selectById" parameterType="int" resultType="User">
- select * from User where id = #{id}
- </select> -->
- </mapper>
IUserOperation.java:
- package com.miquan.mybatis.inter;
- import java.util.List;
- import org.apache.ibatis.annotations.Delete;
- import org.apache.ibatis.annotations.Insert;
- import org.apache.ibatis.annotations.Select;
- import org.apache.ibatis.annotations.Update;
- import com.miquan.mybatis.bean.User;
- public interface IUserOperation {
- @Select("select * from User where id = #{id}")
- public User selectById(int id);
- @Select("select * from User where userName = #{userName}")
- public List<User> selectUsers(String userName);
- @Insert("insert into User values(null, #{userName}, #{password})")
- public boolean addUser(User user);
- @Delete("delete from User where id = #{id}")
- public boolean delUser(int id);
- @Update("update User "
- + "set userName = #{userName}, "
- + "password = #{password} "
- + "where id = #{id}")
- public boolean updateUser(User user);
- }
注意:此处接口不支持多态。
(不知道为什么,用着就是不可以。。。方法名不能一样)
最后进行测试:Test.java:
- package com.miquan.mybatis.test;
- import java.io.InputStream;
- import java.util.List;
- import org.apache.ibatis.io.Resources;
- import org.apache.ibatis.session.SqlSession;
- import org.apache.ibatis.session.SqlSessionFactory;
- import org.apache.ibatis.session.SqlSessionFactoryBuilder;
- import com.miquan.mybatis.bean.User;
- import com.miquan.mybatis.inter.IUserOperation;
- public class Test {
- static SqlSession session;
- public static void main(String[] args) {
- try {
- //获取session
- InputStream is = Resources.getResourceAsStream("mybatisconfig.xml");
- SqlSessionFactory sqlSessionFactory =
- new SqlSessionFactoryBuilder().build(is);
- session = sqlSessionFactory.openSession();
- //XML配置对应用法
- // User user = session.selectOne("com.miquan.mybatis.bean.UserDB.selectById", 1);
- // System.out.println(user.toString());
- //接口调用法
- //////注意:insert、delete和update方法调用之后必须commit才能真正的改变数据
- IUserOperation userOperation = session.getMapper(IUserOperation.class);
- //查
- // User user = userOperation.selectById(1);
- // System.out.println(user.toString());
- //查找List
- // List<User> users = userOperation.selectUsers("miquan");
- // System.out.println(users.size());
- //增
- // User user = new User();
- // user.setUserName("zhiquan");
- // user.setPassword("999");
- // userOperation.addUser(user);
- // session.commit();
- //删
- // userOperation.delUser(7);
- // session.commit();
- //改
- User user = new User(8, "qiantu", "shaxppp");
- userOperation.updateUser(user);
- session.commit();
- } catch (Exception e) {
- e.printStackTrace();
- } finally {
- try {
- session.close();
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- }
- }
简单的增删查改可以实现了。
[转]mybatis 的简单使用的更多相关文章
- Mybatis框架简单使用
Mybatis框架简单使用 环境搭建 新建一个JavaWeb项目,在web\WEB-INF\创建lib文件,并且在其下添加Mybatis的核心包以及依赖包,以及Mysql驱动包,junit4测试包等. ...
- MyBatis(1)-简单入门
简介 什么是 MyBatis ? MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.My ...
- MyBatis 使用简单的 XML或注解用于配置和原始映射
MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为MyBatis .My ...
- 单独使用MyBatis的简单示例
单独使用MyBatis的简单示例:mybaties-config.xml:MyBatis配置文件 <?xml version="1.0" encoding="UTF ...
- Mybatis的简单增删改查
刚开始学习Mybatis可以先看下官方文档,MyBatis是支持定制化SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis避免了几乎所有的JDBC代码和手工设置参数以及抽取结果集.MyBat ...
- Mybatis实现简单的CRUD(增删改查)原理及实例分析
Mybatis实现简单的CRUD(增删改查) 用到的数据库: CREATE DATABASE `mybatis`; USE `mybatis`; DROP TABLE IF EXISTS `user` ...
- Mybatis实现简单增删改查
Mybatis的简单应用 学习内容: 需求 环境准备 代码 总结: 学习内容: 需求 使用Mybatis实现简单增删改查(以下是在IDEA中实现的,其他开发工具中,代码一样) jar 包下载:http ...
- MyBatis学习--简单的增删改查
jdbc程序 在学习MyBatis的时候先简单了解下JDBC编程的方式,我们以一个简单的查询为例,使用JDBC编程,如下: Public static void main(String[] args) ...
- Mybatis的简单示例
首先新建一个JavaWeb项目并导入mybatis依赖的jar包,同时Mybatis是对数据库的操作所以我们需要在数据库中新建一个表user用来演示. 新建完表之后我们还需要建立相对应的实体类User ...
- MyBatis的简单操作
这里将的是简单的增.删.改.查等基本操作 首先创建java项目,导入相应的依赖包,这里可以参考上一篇博客 1.添加数据 在jike.book.pojo包中,新建java类 JiKeUser.java: ...
随机推荐
- C基础 时间业务实战代码
引言 业务代码中遇到这样需求, 1. 二者是同一天吗, 2. 时间戳和时间串来回转, 3. 其它扩展需求 等. C写代码同样需要处理这方面时间问题. 本文就是为了解决这个问题. 相比其它时间库, 这里 ...
- Lambda 表达式 in java 8
Lambda 表达式 in Java 8 Lambda表达式是java 8 新增的特性 Lambda表达式主要作用:支持将代码块作为方法参数,允许使用更简洁的代码创建函数式接口的实例,是匿名内部类的一 ...
- iframe弹出框js ie6下存在bug
ie6的iframe在第一次加载的显示不出来,显示空白,但是很奇怪,刷新就可以正常显示了,一开始以为这只是IE6下iframe加载的bug,但是最后结果发现这是ie6下javascript延迟加载出现 ...
- C入门之一
1.stdio.h不要写错成studio.h 2. #include <stdio.h> int main() { /* 我的第一个 C 程序 */ printf("Hello, ...
- 在JAVASCRIPT中构建一个复杂的对象,并用JSON进行转换
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- HBase shell 命令创建表及添加数据操作
创建表,表名hbase_1102,HBase表是由Key-Value组成的,此表中Key为NAME 此表有两个列族,CF1和CF2,其中CF1和CF2下分别有两个列name和gender,Chin ...
- 前端读者 | 前端面试基础手册(HTML+CSS)
本文来自@羯瑞:希望前端面试基础手册能帮助要找工作的前端小伙伴~~ HTML 前端需要注意哪些SEO? 合理的title.description.keywords:搜索对着三项的权重逐个减小,titl ...
- CentOS7配置sentinel高可用redis
redis哨兵:用于管理和实现多个redis组实现高可用,sentinel哨兵只监控主节点,因为主节点上有所有的从节点信息,当master节点发生故障,sentinel之间会进行投票选举一个slave ...
- mongoDB学习第一天之增删改查
mongoDB 是 no-sql 的一种数据库. 创建数据库: use dbName #数据库中如果存在 dbName ,切换到此数据库:如果不存在此数据库,则创建 dbName 数据库!(tip:当 ...
- NOIP2018 提高组题解
Day1 T1 据说是原题积木大赛,但是考场上蠢了,只会写数据结构,于是写了一个线段树\(+\)堆\(+\)贪心,先选出最小的,然后区间修改,然后把左右两端区间的最小值丢进堆里,不停从堆中去最小值更新 ...