MyBatis入门及CRUD
MyBatis是一个ORM的数据操作框架
myBatis的基本配置
首先创建一个普通 java项目,引入响应jar包,然后引入mybatis的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> <!--链接properties-->
<properties resource="jdbc.properties" /> <!--设置他的别名 设为包的话别名就是包下面的类名-->
<typeAliases>
<package name="cn.newsoft.domain"></package>
</typeAliases> <!--配置环境们
default:默认使用的哪个环境
-->
<environments default="development"> <!--配置单个环境-->
<environment id="development">
<!--配置事务,有这两个属性
JDBC:使用JDBC的默认事务功能
MANAGED:表示没有事务
-->
<transactionManager type="JDBC"/>
<!--配置连接池-->
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="username" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</dataSource>
</environment>
</environments>
<!--引入写sql语句的xml文件-->
<mappers>
<mapper resource="cn/newsoft/test/productMapper.xml"/>
</mappers>
</configuration>
配置链接数据库的properties文件
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql:///自己的数据库名
jdbc.username=自己用户名
jdbc.password=数据库密码
然后写好domain对象,然后在测试类写一个xml,这个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"> <mapper namespace="cn.newsoft.test.productMapper">
<!--parametertype表示传入参数的类型
resulttype表示每一条数据传出时的类型
-->
当damian中数据库字段和domain中的不对应时就可以用这个方法来统一字段
<resultMap id="prductMap" type="Product">
<result column="dir_id" property="dirId"></result> </resultMap> <!--查询一个-->
<select id="findone" parameterType="long" resultType="Product">
select * from product where id = #{id}
</select> <!--查询全部-->
<select id="findAll" resultMap="prductMap">
select * from product
</select> <!--添加操作-->
<insert id="insert" parameterType="Product">
insert into product(productName,dir_id,salePrice,supplier,brand,cutoff,costPrice)
values (#{productName},#{dirId},#{salePrice},#{supplier},#{brand},#{cutoff},#{costPrice})
</insert> <!--修改操作-->
<update id="update" parameterType="Product" >
update product set productName=#{productName},dir_id=#{dirId},salePrice=#{salePrice},
supplier=#{supplier},brand=#{brand},cutoff=#{cutoff},costPrice=#{costPrice} where id=#{id} </update>
<!--删除一个-->
<delete id="delete" parameterType="long">
delete from product where id=#{id}
</delete>
</mapper>
然后我们定义一个工具类用来获取sqlsession对象
package cn.newsoft.util; 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 java.io.IOException;
import java.io.Reader; public class MybatisUtil {
private static SqlSessionFactory build;
static {
try {
Reader resource = Resources.getResourceAsReader("mybatis.xml");
build = new SqlSessionFactoryBuilder().build(resource); } catch (IOException e) {
e.printStackTrace();
}
} public static SqlSession gtSession(){
SqlSession sqlSession = build.openSession();
return sqlSession; } }
dao层为
package cn.newsoft.dao.impl; import cn.newsoft.dao.IproductDao;
import cn.newsoft.domain.Product;
import cn.newsoft.util.MybatisUtil;
import org.apache.ibatis.session.SqlSession; import java.util.List; public class ProductImpl implements IproductDao { @Override
public void save(Product product) {
SqlSession sqlSession = MybatisUtil.gtSession();
sqlSession.insert("cn.newsoft.test.productMapper.insert", product); }
//cn.newsoft.test.productMapper.update"为命名空间的全限定名 update执行的方法名称
@Override
public void update(Product product) {
SqlSession sqlSession = MybatisUtil.gtSession();
sqlSession.update("cn.newsoft.test.productMapper.update", product);
} @Override
public void delete(Long id) {
SqlSession sqlSession = MybatisUtil.gtSession();
sqlSession.delete("cn.newsoft.test.productMapper.delete", id);
} @Override
public Product findone(Long id) {
SqlSession sqlSession = MybatisUtil.gtSession();
Product o = (Product)sqlSession.selectOne("cn.newsoft.test.productMapper.findone",id);
return o;
} @Override
public List<Product> findAll() {
SqlSession sqlSession = MybatisUtil.gtSession();
List<Product> list = sqlSession.selectList("cn.newsoft.test.productMapper.findAll");
return list;
}
}
然后在测试类中进行测试
package cn.newsoft.test; import cn.newsoft.dao.impl.ProductImpl;
import cn.newsoft.domain.Product;
import cn.newsoft.util.MybatisUtil;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test; import java.util.List; public class IproductDaoTest { ProductImpl products = new ProductImpl();
@Test
public void save() { Product product = new Product();
product.setProductName("sss");
product.setSupplier("changcu");
products.save(product); } @Test
public void update() {
Product findone = products.findone(22L);
findone.setProductName("李逵");
products.update(findone);
} @Test
public void delete() {
products.delete(21L);
} @Test
public void findone() { Product findone = products.findone(1L);
System.out.println(findone);
} @Test
public void findAll() {
List<Product> all = products.findAll();
all.forEach(e ->
System.out.println(e));
}
}
这样就完成他的CRUD,
日志管理
引入jar包
#log4j.properties(日志文件:)
# ERROR错误的日志 WARN:警告 INFO:普通信息 DEBUG:调试日志 TRACE:日志
log4j.rootLogger=ERROR, stdout
#log4j.rootLogger=NONE
#把左边包名改成你自己的包名
log4j.logger.cn.itsource=TRACE # 日志打印到控制台中
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
# 日志打印的一种格式(可以灵活地指定布局模式)
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
# 日志打印的格式是什么样子的 %d:日期 %p:优先级 %c:类的全名 %m:输出的结果 %n:换行
log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] - %m%n
MyBatis入门及CRUD的更多相关文章
- mybatis入门,CRUD,万能Map,模糊查询
第一个Mybatis程序 核心配置文件mybatis-config.xml <?xml version="1.0" encoding="UTF-8" ?& ...
- MyBatis入门学习教程-使用MyBatis对表执行CRUD操作
上一篇MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对use ...
- MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作(转载)
本文转载自:http://www.cnblogs.com/jpf-java/p/6013540.html 上一篇博文MyBatis学习总结(一)--MyBatis快速入门中我们讲了如何使用Mybati ...
- MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作
上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据,算是对MyBatis有一个初步的入门了,今天讲解一下如何使用MyBatis对u ...
- 【转】MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作
[转]MyBatis学习总结(二)——使用MyBatis对表执行CRUD操作 上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用Mybatis查询users表中的数据, ...
- Mybatis入门看这一篇就够了
什么是MyBatis MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改名为 ...
- 【转载】 mybatis入门系列四之动态SQL
mybatis 详解(五)------动态SQL 目录 1.动态SQL:if 语句 2.动态SQL:if+where 语句 3.动态SQL:if+set 语句 4.动态SQL:choose(when, ...
- MyBatis学习笔记(二)——使用MyBatis对表执行CRUD操作
转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4262895.html 上一篇博文MyBatis学习总结(一)——MyBatis快速入门中我们讲了如何使用My ...
- Mybatis系列(一):Mybatis入门
一.Mybatis是什么 MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google code,并且改 ...
随机推荐
- Python处理文本换行符
源文件每行后面都有回车,所以用下面输出时,中间会多了一行 try: with open("F:\\hjt.txt" ) as f : for line in f: print(li ...
- node.js中实现同步操作的3种实现方法
这篇文章主要介绍了node.js中实现同步操作的3种实现方法,本文用实例讲解一些需要同步操作的情况下,如何编程实现,需要的朋友可以参考下 众所周知,异步是得天独厚的特点和优势,但同时在程序中同步的需求 ...
- js 倒计时功能,获取当前时间的年月日,时分秒
一.实现当前时间到指定截止时间的倒计时功能 <html> <head> <title>TEST</title> </head> <bo ...
- input实时监听控制输入框的输入内容和长度,并进行提示和反馈
一.前言 在MVVM模式下,有个双向数据绑定(data-binding)的优势,可以通过viewmodel实时的监听用户操作,也可以将model的改动实时的反馈到界面上. 那么,在传统的js操控DOM ...
- 微信小程序地图之逆地理编码
首先说一下,我微信自带map的api中并没有相关接口可调用.文中的方法建立于高德地图.(顺便吐槽,微信开发文档相比支付宝家的显得好烂!) 最近做项目用到地图定位相关的需求,为了搞定需求看了下相关的文档 ...
- 286 walls and gate最近的出口
[抄题]: 您将获得一个使用这三个可能值初始化的 m×n 2D 网格.-1 - 墙壁或障碍物. 0 - 门. INF - Infinity是一个空房间.我们使用值 2 ^ 31 - 1 = 21474 ...
- Kafka管理工具介绍
Kafka内部提供了许多管理脚本,这些脚本都放在$KAFKA_HOME/bin目录下,而这些类的实现都是放在源码的kafka/core/src/main/scala/kafka/tools/路径下. ...
- html符号转换
通常情况下,HTML会自动截去多余的空格.不管你加多少空格,都被看做一个空格.比如你在两个字之间加了10个空格,HTML会截去9个空格,只保留一个.为了在网页中增加空格,你可以使用 表示空格.最常用的 ...
- HDU 6065 RXD, tree and sequence (LCA+DP)
题意:给定上一棵树和一个排列,然后问你把这个排列分成m个连续的部分,每个部分的大小的是两两相邻的LCA的最小深度,问你最小是多少. 析:首先这个肯定是DP,然后每个部分其实就是里面最小的那个LCA的深 ...
- Codeforces761B Dasha and friends 2017-02-05 23:34 162人阅读 评论(0) 收藏
B. Dasha and friends time limit per test 2 seconds memory limit per test 256 megabytes input standar ...