首先在lib下导入:
与打印日志信息有关的架包 log4j-1.2.16.jar
mybatis架包:mybatis-3.1.1.jar
连接数据库的架包:mysql-connector-java-5.1.6-bin.jar
建立User封装类,这儿只写属性,不写setter和getter,tostring方法
private int id;
private String name;
private int age;
在src目录下建立db.properties文件,连接数据库的属性和值
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis
username=root
password=lxn123
在src目录下建立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>
<!--
environments:开发模式
work:工作模式
default="development",id="development",两个的属性值必须一致
-->
<!-- 导入连接数据库的配置资源 -->
<properties resource="db.properties"/> <!-- 为包下 映射文件中 parameterType 和 resultType(属性的类型和结果的类型,
有时候是全类名,较长,所以配置一个别名) 配置别名 -->
<typeAliases>
<typeAlias type="com.atguigu.mybatis.test.User" alias="TTUser"/>
</typeAliases> <environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments> <!-- 在配置文件中 关联包下的 映射文件
resource="com/atguigu/mybatis/test/userMapping.xml"为路径结构 -->
<mappers>
<mapper resource="com/atguigu/mybatis/test2/userMapping.xml"/>
</mappers>
</configuration>
在该包下建立userMapping.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"> <!-- namespace 包名+文件名,是为了使这个文件唯一,因为这个包下可以建立好多个封装类,同时也可以建立好多个映射文件 -->
<mapper namespace="com.atguigu.mybatis.test2.userMapper">
<!-- 基于xml的增删改查操作
parameterType, 是封装类的全类名-->
<insert id="addUser" parameterType="TTUser">
insert into users(name,age) values(#{name},#{age})
</insert> <delete id="deleteUser" parameterType="int">
delete from users where id=#{id}
</delete> <update id="updateUser" parameterType="TTUser">
update users set name=#{name},age=#{age} where id=#{id}
</update> <!-- resultType返回的是 封装属性类的全类名,查询结果返回的是一个list集合,泛型是User,即返回的是这个 -->
<select id="getAllUser" resultType="TTUser">
select * from users
</select> <!-- 根据id查询得到一个user对象
占位符 #{id}中的值 可以随便写,但是一般是和等号前边一致的
parameterType 参数的类型
resultType 结果类型,即封装类的全类名,是用反射实现的-->
<select id="getUser" parameterType="int" resultType="TTUser">
select * from users where id=#{id}
</select>
</mapper>
实现增删改查的方法,由于每个方法中有一些重复且可以提取的代码,所以写在一个类方法
package com.atguigu.mybatis.test2; import java.util.List; import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.junit.Test; import com.atguigu.mybatis.test.MybatisUtils;
import com.atguigu.mybatis.test.User; public class Mybatis2Test { //增加
@Test
public void testAdd(){
SqlSessionFactory factory=MybatisUtils.getFactory(); //默认提交方式为手动的,执行完了以后要手动提交事物,
//也可以在openSession(true),中添加true,取消默认的手动提交事物的方式,从而实现自动提交事物
SqlSession session=factory.openSession(); //com.atguigu.mybatis.test2.userMapper.addUser
//是映射文件中 namespace="com.atguigu.mybatis.test2.userMapper".id="addUser",组合而成
String statement="com.atguigu.mybatis.test2.userMapper.addUser"; //这儿id是自增的不需要添加,所以是-1
session.insert(statement, new User(-1, "panpan", 14)); //执行完了以后,手动提交事物
session.commit(); //每次执行完事物就将它关闭
session.close();
} //修改
@Test
public void testUpdate(){
SqlSessionFactory factory=MybatisUtils.getFactory(); //在openSession(true),中添加true,取消默认的手动提交事物的方式,从而实现自动提交事物
SqlSession session=factory.openSession(true);
String statement="com.atguigu.mybatis.test2.userMapper.updateUser";
session.update(statement, new User(7, "jjj", 234));
session.close();
} //删除
@Test
public void testDelete(){
SqlSessionFactory factory=MybatisUtils.getFactory();
SqlSession session=factory.openSession(true);
String statement="com.atguigu.mybatis.test2.userMapper.deleteUser";
session.delete(statement, 7);
session.close();
} //查询单个数据
@Test
public void testOneSelect(){
SqlSessionFactory factory=MybatisUtils.getFactory();
SqlSession session=factory.openSession(true);
String statement="com.atguigu.mybatis.test2.userMapper.getUser";
//查询时,将查询的结果放在User的构造函数中
User user=session.selectOne(statement, 2);
session.close();
System.out.println(user);
} //查询所有的数据
@Test
public void testSelect(){
SqlSessionFactory factory=MybatisUtils.getFactory();
SqlSession session=factory.openSession(true);
String statement="com.atguigu.mybatis.test2.userMapper.getAllUser";
List<User> list=session.selectList(statement);
session.close();
System.out.println(list);
}
}
实现增删改查共有的代码,写在一个类方法中,使用时,直接调用
package com.atguigu.mybatis.test; import java.io.InputStream; import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder; public class MybatisUtils {
public static SqlSessionFactory getFactory(){
String resource="conf.xml"; //加载mybatis 的配置文件(它也加载关联的映射文件)
InputStream is=MybatisUtils.class.getClassLoader().getResourceAsStream(resource); //构建sqlSession 的工厂
SqlSessionFactory factory=new SqlSessionFactoryBuilder().build(is);
return factory;
}
}
可以在src 下加入log4j.xml 的配置文件,打印日志信息,但是必须导入打印日志信息的架包
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/"> <appender name="STDOUT" class="org.apache.log4j.ConsoleAppender">
<!-- 在控制台输出,格式 -->
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%-5p %d{MM-dd HH:mm:ss,SSS} %m (%F:%L) \n" />
</layout>
</appender> <!-- 打印sql方面有关的日志 -->
<logger name="java.sql">
<level value="debug" />
</logger> <logger name="org.apache.ibatis">
<level value="debug" />
</logger> <root>
<level value="debug" />
<appender-ref ref="STDOUT" />
</root>
</log4j:configuration>
Mybatis框架基于映射文件和配置文件的方式,实现增删改查,可以打印日志信息的更多相关文章
-
MyBatis的SQL语句映射文件详解(二)----增删改查
1.select语句 public List<User> findUser() { // TODO Auto-generated method stub List users= ( ...
-
MyBatis学习(三)MyBatis基于动态代理方式的增删改查
1.前言 上一期讲到MyBatis-Statement版本的增删改查.可以发现.这种代码写下来冗余的地方特别多.写一套没啥.如果涉及到多表多查询的时候就容易出现问题.故.官方推荐了一种方法.即MyBa ...
-
Spring Boot入门系列(十八)整合mybatis,使用注解的方式实现增删改查
之前介绍了Spring Boot 整合mybatis 使用xml配置的方式实现增删改查,还介绍了自定义mapper 实现复杂多表关联查询.虽然目前 mybatis 使用xml 配置的方式 已经极大减轻 ...
-
02.Mybatis的动态代理方式实现增删改查
动态代理的方式实现增删改查: 通过约定的方式定位sql语句 约定 > 配置文件 > 硬编码 约定的目标是省略掉通过硬编码的方式定位sql的代码,通过接口直接定位出sql语句,以下代码为通过 ...
-
基于gin的golang web开发:mysql增删改查
Go语言访问mysql数据库需要用到标准库database/sql和mysql的驱动.标准库的Api使用比较繁琐这里再引入另一个库github.com/jmoiron/sqlx. go get git ...
-
搭建ssm框架,可实现登录和数据展示以及增删改查
需求: 后台使用ssm(spring-springMVC-mybatis)进行整合 前台使用bootstrap框架 前后台交互使用Ajax进行发送 表结构: 登录页面后显示所有用户信息,可对每条进行增 ...
-
SSM框架入门——整合SSM并实现对数据的增删改查功能(Eclipse平台)
一.搭建框架环境 整个项目结构如下: 搭建SSM步骤如下: (1)准备好三大框架的jar包,如图所示 (2)在Eclipse中创建一个web project ,并把这些jar包粘贴到lib文件夹中. ...
-
基于SpringBoot开发一个Restful服务,实现增删改查功能
前言 在去年的时候,在各种渠道中略微的了解了SpringBoot,在开发web项目的时候是如何的方便.快捷.但是当时并没有认真的去学习下,毕竟感觉自己在Struts和SpringMVC都用得不太熟练. ...
-
Mybatis学习笔记(二) 之实现数据库的增删改查
开发环境搭建 mybatis 的开发环境搭建,选择: eclipse j2ee 版本,mysql 5.1 ,jdk 1.7,mybatis3.2.0.jar包.这些软件工具均可以到各自的官方网站上下载 ...
随机推荐
-
长见识了,知道了collected和Graphite 这两个东东
今天下午的讨论会议中,听到了两个名词collected和Graphite这是神马东东,以前在bingo的时候也没听说过,开完会下去查了下.原来他两是监控系统的啊.以前也从来没做过系统监控方面的项目,这 ...
-
PHP之路,Day1 - PHP基础
本节内容 1.PHP介绍 2.第一个PHP脚本程序 3.PHP语言标记 4.指令分割符 5.程序注释 6.在程序中使用空白符的处理 7.变量 8.变量的类型 9.数据类型之间相互转换 ...
-
Android libyuv应用系列(二)libyuv的使用
上篇文章Android libyuv使用系列(一)Android常用的几种格式:NV21/NV12/YV12/YUV420P的区别中我们了解了YUV相关的知识,而本篇文章我会介绍libyuv是什么,以 ...
-
CentOS 7 BIND 搭建
域名查找顺序 设置 /etc/host.conf 1. bind 安装 $ yum install bind bind-utilsnslookup (name server lookup) 在bind ...
-
RACSingle 有效的两种方式
第一种当然是subscribeNext 另外还有一种就是作为Command的enablesingle也相当于被订阅了.
-
[SPOJ 10628]Count on a tree
Description 题库链接 求不带修改的树上路径第 \(K\) 小. \(N\) 个节点 \(M\) 组询问. \(1\leq N,M\leq 100000\) Solution 主席树维护树上 ...
-
微信小程序报错,不在以下 request 合法域名列表中(引起的探索)
最近因为突然对小程序有兴趣,然后开始了自学之旅. 在学习的过程当中遇到了一个问题,控制台报错,提示:不在以下 request 合法域名列表中,如下图所示 然后我就开始了搜索之旅,相对觉得 ...
-
as项目找不到id
是app目录下一个iml文件的问题,从备份恢复就好了
-
IP通信基础课堂笔记----第二章(重点)
TCP报文及传输 TCP报文主要学习的内容包括,报文格式.连接管理.流量控制.差错控制. TCP报文是由报文头部和数据两个部分组成.占20字节的报文头部包括源端口.位目的端口.序号..确认号.首部长度 ...
-
Android开发之实现多次点击事件
在Android中给我们提供了单次点击事件.但并没有给我们提供双击,或者实现在一定时间内的多次事件.所以需要我们自己在单机监听上进行修改实现. 有如下两种实现方式: 1.定义一个存贮上一个第一次点击的 ...