2.mybatis入门实例 连接数据库进行查询
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&useUnicode=true&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入门实例 连接数据库进行查询的更多相关文章
- Mybatis入门实例
MyBatis 简介 MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis ...
- Mybatis入门实例解析
写在前面:本文全程根据Mybatis官网进行入门讲解.毫无疑问,官方文档是学习这门技术最权威的资料,与此同时我们也知道官方文档对待入门小白基本上不太友好,没有入门demo.开篇就是小白们不懂的内容.有 ...
- MyBatis入门实例-包括实体类与数据库字段对应&CLOB字段处理
1.我的开发环境是 jdk1.7+ecplise+oracle 11g 用到的jar包:mybatis-3.1.1.jar ojdbc6.jar 2.项目整体结构 3.首先配置conf.xml ...
- MyBatis入门实例 ——Mapper.xml(zz)
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBL ...
- mybatis入门案例分析
mybatis入门案例分析 一.设计模式分析 public class MybatisTest { public static void main(String[] args) throws Exce ...
- mybatis 详解(二)------入门实例(基于XML)
通过上一小节,mybatis 和 jdbc 的区别:http://www.cnblogs.com/ysocean/p/7271600.html,我们对 mybatis有了一个大致的了解,下面我们通过一 ...
- mybatis 详解(三)------入门实例(基于注解)
1.创建MySQL数据库:mybatisDemo和表:user 详情参考:mybatis 详解(二)------入门实例(基于XML) 一致 2.建立一个Java工程,并导入相应的jar包,具体目录如 ...
- mybatis学习一:基于xml与注解配置入门实例与问题
注:本case参考自:http://www.cnblogs.com/ysocean/p/7277545.html 一:Mybatis的介绍: MyBatis 本是apache的一个开源项目iBatis ...
- MyBatis基础入门《八》查询参数传入Map
MyBatis基础入门<八>查询参数传入Map 描述: 在执行select查询数据的时候,方法传入的参数是java.util.Map类型. 接口方法: xml文件 注意: 书写SQL语句的 ...
随机推荐
- 使用Mysql ID自增长时 在Mapper的<insert>里添加对应的代码
<selectKey keyProperty="id" order="AFTER" resultType="java.lang.Long&quo ...
- innodb内部的并发线程
1. innodb_thread_concurrency innodb有一系列的计数器来统计和控制内部的工作线程.其中最重要的一个是innodb_thread_concurrency,和它相关的inn ...
- laravel5.1启动详解
laravel的启动过程 如果没有使用过类似Yii之类的框架,直接去看laravel,会有点一脸迷糊的感觉,起码我是这样的.laravel的启动过程,也是laravel的核心,对这个过程有一个了解,有 ...
- Http的常见问题
A: HTTP(超文本传输协议)是一个基于请求与响应模式的.无状态的.应用层的协议. B: 文件传输协议FTP.电子邮件传输协议SMTP.域名系统服务DNS.HTTP协议等都同是应用层协议. C:HT ...
- 【转载】使用barman备份PostgreSQL
什么是barman Barman (备份和恢复管理器) 是 PostgreSQL 数据库服务器中非常方便的备份和恢复工具,允许远程备份多个服务器,允许从一个备份集中一个命令就恢复数据库.同时还可以对多 ...
- [ios][swift]Swift类型之间转换
http://www.ruanman.net/swift/learn/4741.html
- 山东理工大学第七届ACM校赛-字符的变化 分类: 比赛 2015-06-26 10:32 46人阅读 评论(0) 收藏
字符的变化 Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描述 一个长度为n(1<=n<=1000)的字符串(只包含小写字 ...
- XMLHttpRequest 2.0与FileReader接口的方法
jsonpd的实现: var jsonp = function (options) { var url = options.url, params = options.params || {}, ca ...
- linux下如何安装配置redis及主从配置
redis的优点:支持主从备份,操作指令丰富,支持异步的数据持久化 将 redis 安装到 /usr/local/webserver/redis 1.下载安装包 wget http://redis.g ...
- nltk安装及wordnet使用详解
环境:python2.7.10 首先安装pip 在https://pip.pypa.io/en/stable/installing/ 下载get-pip.py 然后执行 python get-pip. ...