mybatis的dao的mapper写法
## MyBatis的Dao编写【mapper代理方式实现】
step1: 写一个接口,并写抽象方法;
package com.sjl.mapper;
import com.sjl.model.User;
public interface UserMapper {
/*
* 保存一个用户
* */
public int save(User user);//返回受影响的行数
public User findUserById(int id);
}
step2: 在同包下建一个UserMapper.xml(具体sql方法的显现类的方法的实现),这个相当于
是DAO的实现类,MyBatis会为mapper接口生成动态代理实现类;(配置文件相当于是DAO的
实现类,里面是一些具体的增删改查的方法)
(说明:入参,返回值,id等要与接口类中的对应,具体看下面的注释)
<?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="com.sjl.mapper.UserMapper">
<insert id="save" parameterType="com.sjl.mapper.User">
insert into user(username,sex,birthday,address)
value (#{username},#{sex},#{birthday},#{address});
</insert> <!--受影响的返回的行数不用写,可以不用写,无意义--> <select id="findUserById" parameterType="int"
resultType="com.sjl.mapper.User"> </select> </mapper>
<!--
com.sjl.mapper.UserMapper 包名+接口名
id="save" 方法名
parameterType="com.sjl.mapper.User" 入参
resultType 返回结果
--> step3:在src下的sqlconf.xml中的添加如下内容,加载执行DAO方法的映射文件;
<mappers>
<!--写映射文件的名字-->
<mapper resource="com/gyf/mapper/UserMapper.xml"></mapper>
</mappers>
step4:测试类;
package com.sjl.test; import com.sjl.mapper.UserMapper;
import com.sjl.model.User;
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 org.junit.After;
import org.junit.Before;
import org.junit.Test; import java.io.IOException;
import java.io.InputStream;
import java.util.Date;
import java.util.List; public class Demo02 {
SqlSession session; @Before
public void before() throws IOException{
System.out.println("before...获取session");
//a)读取配置文件;
InputStream is=Resources.getResourceAsStream("SqlMapConfig.xml");
//b)通过SqlSessionFactoryBuilder创建SqlSessionFactory会话工厂 。
SqlSessionFactory sessionFactory=new SqlSessionFactoryBuilder().build(is);
// c)通过SqlSessionFactory创建SqlSession。
session=sessionFactory.openSession();
}
@After
public void after(){ //关闭SqlSession。
session.close();
} @Test
public void test1() throws IOException{
//通过session拿到这个接口的代理 代理直接转成接口的实现类,并指向UserMapper这个接口
UserMapper userMapper=session.getMapper(UserMapper.class); //获取数据
System.out.println(userMapper.findUserById(1)); //保存
User user2=new User("xx","x",new Date(),"xx");
userMapper.save(user2);
session.commit();
}
51 }
--------------------------------------------------------------------------------------------------
MyBatis 入门程序步骤:
1).用Mysql终端建库、建表;
2).添加核心jar包和依赖(Mysql驱动jar);
3).建立日志log4j.properties(用于控制台输出sql的);
4).依据数据库字段进行写一个javaBean
5).src目录下建一个xxxMapper.xml这个映射文件是用来配置sql的。
6) .src目录下建一个核心配置文件mybatis-config.xml用来配置数据库和数据库连接池等信息,并添加一个文件来加载所有的映射;
7).src目录下建一个测试包,测试包下建一个测试类。
mybatis的dao的mapper写法的更多相关文章
- mybatis开发Dao的Mapper动态代理方式
1. 开发规范Mapper接口开发方法只需要程序员编写Mapper接口(相当于Dao接口),由Mybatis框架根据接口定义创建接口的动态代理对象,代理对象的方法体跟Dao原始方法中接口实现类的方法相 ...
- mybatis使用Dao和Mapper方式
1.配置jdcp.properties数据库连接文件 #mysql database setting jdbc.type=mysql jdbc.driver=com.mysql.jdbc.Driver ...
- Mybatis的Dao向mapper传多个参数(三种解决方案)转自《super超人》
第一种方案 : DAO层的函数方法 Public User selectUser(String name,String area); 对应的Mapper.xml <select id=" ...
- Mybatis的Dao向mapper传多个参数(三种解决方案)
第一种方案 : DAO层的函数方法 Public User selectUser(String name,String area); 对应的Mapper.xml <select id=" ...
- mybatis的dao向mapper.xml传入多参数
https://www.cnblogs.com/super-chao/p/7722411.html 如果两种不同类型的参数传入,parameterType可以不写,直接获取#{0},#{1}就可以传入 ...
- Spring+SpringMVC+MyBatis深入学习及搭建(二)——MyBatis原始Dao开发和mapper代理开发
转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/6869133.html 前面有写到Spring+SpringMVC+MyBatis深入学习及搭建(一)——My ...
- mybatis根据数据库表结构自动生成实体类,dao,mapper
首先, pom需要引入 <!-- mysql --> <dependency> <groupId>mysql</groupId> <artifac ...
- mybatis自动生成service、dao、mapper
1.config.properties ## 数据库连接参数 jdbc.driverClass = com.mysql.jdbc.Driver jdbc.url = jdbc:mysql://loca ...
- MyBatis开发Dao层的两种方式(Mapper动态代理方式)
MyBatis开发原始Dao层请阅读我的上一篇博客:MyBatis开发Dao层的两种方式(原始Dao层开发) 接上一篇博客继续介绍MyBatis开发Dao层的第二种方式:Mapper动态代理方式 Ma ...
随机推荐
- C++的函数功能总结
1. string中find()返回值是字母在母串中的位置(下标记录),如果没有找到,返回npos. 2.string的substr(pos=0, count=npos)返回字符串[pos, pos+ ...
- css3径向渐变
#grad2 { height: 440px; width: 440px; border-radius: %; background: -webkit-radial-gradient(closest- ...
- python socket 老生常谈
没啥可说的,直接看代码 //server import socket s = socket.socket() host = socket.gethostname() print 'host: ', h ...
- unity3d-游戏实战突出重围,第三天 绘制数字
实现效果: 准备资源 using UnityEngine; using System.Collections; public class hznum : MonoBehaviour { //存储图片资 ...
- 关于 CGI,Fastcgi和php-fpm 理解
首先,CGI是干嘛的?CGI是为了保证web server传递过来的数据是标准格式的,方便CGI程序的编写者. web server(比如说nginx)只是内容的分发者.比如,如果请求/index.h ...
- Linux 服务器配置网站以及绑定域名
Linux 服务器如何配置网站以及绑定域名 转载来源:http://www.xinnet.com/service/cjwt/idc/guanli/1424.html 以下列举一些 主机上常见的 Web ...
- Java -- 深入浅出GC自动回收机制
1,去年开春去美团和58同城面试的时候第一个问题基本上都是来说说 Java GC机制,当时年轻的我也很耿直,直接说不会,现在想想还是当时年轻啊.刚好这段时间被各大论坛的面试题刷屏,见到最多的也是也是这 ...
- 关于linux下firefox无法播放mp3文件
起因是发现在线翻译的网站没法发音. F12调出console,发现是没法解码mp3文件. 尝试安装deadbeef包,发现安装之后推荐安装的软件列表中有个名为ffmpeg的包.安装上之后,重启fire ...
- Unity shader学习之屏幕后期处理效果之Bloom效果
Bloom特效是游戏中常见的一种屏幕效果.这种特效可以模拟真实摄像机的一种图像效果,它让画面中较亮的区域“扩散”到周围的区域中,造成一种朦胧的效果. Bloom的实现原理很简单,首先根据一个阈值提取出 ...
- 1.python虚拟环境的安装-用以同时使用py2,py3
第一步:安装环境支持[linux下在前加sudo] http://www.lfd.uci.edu/~gohlke/pythonlibs/#pycurl pip install virtualenv 第 ...