第一部分:基本实现

@参考文章,在此基础上略作修改

1,新建maven项目JavaMybatis导入依赖

<dependencies>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.2.8</version>
</dependency>
<dependency>
<groupId>com.microsoft.sqlserver</groupId>
<artifactId>sqljdbc4</artifactId>
<version>4.0</version>
</dependency>
</dependencies>

2,com.mybatis包下新建Yanan.java

package com.mybatis;

public class Yanan {
private int iid;
private String ifullname;
private String iloginname;
private String ipassword; public Yanan() {
} public Yanan(int id, String name) {
this.iid = id;
this.ifullname = name;
} public String getIfullname() {
return ifullname;
} public int getIid() {
return iid;
} public void setIid(int iid) {
this.iid = iid;
} public void setIfullname(String ifullname) {
this.ifullname = ifullname;
} public String getIloginname() {
return iloginname;
} public void setIloginname(String iloginname) {
this.iloginname = iloginname;
} public String getIpassword() {
return ipassword;
} public void setIpassword(String ipassword) {
this.ipassword = ipassword;
}
}

3,根目录下新建Yanan.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 namespace="Yanan">
<select id="selectUser" parameterType="int" resultType="Yanan">
SELECT * FROM Yanan WHERE id = #{id}
</select> <select id="selectUsers" resultType="Yanan">
SELECT * FROM Yanan
</select> </mapper>

4,根目录下新建configuration.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>
<typeAliases>
<typeAlias alias="Yanan" type="com.mybatis.Yanan"></typeAlias>
</typeAliases> <environments default="development">
<environment id="development">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED">
<property name="driver" value="com.microsoft.sqlserver.jdbc.SQLServerDriver" />
<property name="url" value="jdbc:sqlserver://localhost:1433;databaseName=test" />
<property name="username" value="sa" />
<property name="password" value="yanan" />
</dataSource>
</environment>
</environments> <mappers>
<mapper resource="Yanan.xml"/>
</mappers> </configuration>

5.com.controller包下新建测试文件

package com.controller;

import java.io.IOException;
import java.io.Reader;
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.mybatis.Yanan; public class Test { public static void main(String[] args) throws IOException {
// TODO Auto-generated method stub
String resource = "configuration.xml";
Reader reader = Resources.getResourceAsReader(resource);
SqlSessionFactory ssf = new SqlSessionFactoryBuilder().build(reader);
SqlSession session = ssf.openSession();
try{
Yanan user = session.selectOne("selectUser", 1);
System.out.println(user.getIfullname());
System.out.println(user);
System.out.println("--------------分隔线---------------"); List<Yanan> users = session.selectList("selectUsers");
for(int i=0; i<users.size(); i++) {
System.out.println(users.get(i).getIfullname());
} } catch (Exception e) {
e.printStackTrace();
} finally {
session.close();
}
} }

源码包下载:JavaMybatis.rar

建表语句:

/*
Navicat SQL Server Data Transfer Source Server : .
Source Server Version : 105000
Source Host : .:1433
Source Database : test
Source Schema : dbo Target Server Type : SQL Server
Target Server Version : 105000
File Encoding : 65001 Date: 2018-09-04 13:49:17
*/ -- ----------------------------
-- Table structure for yanan
-- ----------------------------
DROP TABLE [dbo].[yanan]
GO
CREATE TABLE [dbo].[yanan] (
[id] int NOT NULL IDENTITY(1,1) ,
[ifullname] varchar(255) NULL ,
[iloginname] varchar(255) NULL ,
[ipassword] varchar(255) NULL
) GO -- ----------------------------
-- Records of yanan
-- ----------------------------
SET IDENTITY_INSERT [dbo].[yanan] ON
GO
INSERT INTO [dbo].[yanan] ([id], [ifullname], [iloginname], [ipassword]) VALUES (N'', N'sd', N'fd', N'sd')
GO
GO
SET IDENTITY_INSERT [dbo].[yanan] OFF
GO -- ----------------------------
-- Indexes structure for table yanan
-- ---------------------------- -- ----------------------------
-- Primary Key structure for table yanan
-- ----------------------------
ALTER TABLE [dbo].[yanan] ADD PRIMARY KEY ([id])
GO

项目结构展示:

第二部分:改造优化

上述方式能实现,但需要建实体类,影响开发和维护效率,下面改造成接口形式且无实体类方式:

为了便于区分(也便于我接下来的项目),把名称结构等做了修改

1,同上(项目名DeleteOrder)

2,cn.yanan.deleteorder.mapper下新建UserMapper接口

package cn.yanan.deleteorder.mapper;

import java.util.List;
import java.util.Map; public interface UserMapper {
Map<String,Object> selectUser(int id);
List<Map<String,Object>> selectUsers();
}

3,根目录下新建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 namespace="cn.yanan.deleteorder.mapper.UserMapper">
<select id="selectUser" parameterType="int" resultType="java.util.Map">
SELECT * FROM Yanan WHERE id = #{id}
</select> <select id="selectUsers" resultType="java.util.Map">
SELECT * FROM Yanan
</select> </mapper>

4,根目录下新建configuration.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 default="development">
<environment id="development">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED">
<property name="driver" value="com.microsoft.sqlserver.jdbc.SQLServerDriver" />
<property name="url" value="jdbc:sqlserver://localhost:1433;databaseName=test" />
<property name="username" value="sa" />
<property name="password" value="yanan" />
</dataSource>
</environment>
</environments> <mappers>
<mapper resource="UserMapper.xml"/>
</mappers> </configuration>

5,cn.yanan.deleteorder.controller包下新建测试文件

package cn.yanan.deleteorder.controller;

import java.io.IOException;
import java.io.Reader;
import java.util.List;
import java.util.Map; 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 cn.yanan.deleteorder.mapper.UserMapper; public class MainController {
public static void main(String[] args) throws IOException {
String resource = "configuration.xml";
Reader reader = Resources.getResourceAsReader(resource);
SqlSessionFactory ssf = new SqlSessionFactoryBuilder().build(reader);
SqlSession session = ssf.openSession();
try{
UserMapper mapper = session.getMapper(UserMapper.class);
Map<String,Object> user = mapper.selectUser(1);
List<Map<String,Object>> users = mapper.selectUsers();
System.out.println(user.get("ifullname"));
System.out.println(user);
System.out.println("--------------分隔线---------------");
for(int i=0; i<users.size(); i++) {
System.out.println(users.get(i).get("ifullname"));
}
} catch (Exception e) {
e.printStackTrace();
} finally {
session.close();
}
}
}

源码包下载:DeleteOrder.rar

建表语句:同上

项目结构展示:

第三部分:继续优化

经过第二部分的优化已经能满足大部分网友的需求了。但对于一些要将该项目导出可运行jar包的网友来说并不能很好地运行,摘自一位博客的说法:

“因为”…/ResourceJar.jar!/resource/….”并不是文件资源定位符的格式 (jar中资源有其专门的URL形式: jar:!/{entry} )”,详细论述@参考博客

所以我们使用如下的方式:

InputStream is=MainController.class.getResourceAsStream("/configuration.xml");
BufferedReader br=new BufferedReader(new InputStreamReader(is));

经过上述步骤你会发现在eclipse下能够正常运行,但jar包还不能加载到配置文件,我们继续进行改造

src同目录下建资源包,并把配置文件拖拽进去,结构如下(上述.getResourceAsStream("/configuration.xml")配置不变)

如此,eclipse中与jar包中都能加载到配置文件了。但此时你会发现新的异常,加载不到configuration中的mapper.xml文件

我们继续改造,打开configuration.xml进行配置

并将此二者拖拽到configuration.xml同目录下:

至此,大事告成!

此时博主已整合了大量项目业务,不便将源码包发给大家,思路有了,我也写的很清晰,读者自行整理吧

纯java+maven+sqlserver使用mybatis的更多相关文章

  1. 纯JAVA驱动:sqlserver版本不同,驱动与连接也有所区别

    纯JAVA驱动:// 2005 版本:驱动:Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");连接:”jd ...

  2. Hibernate从入门到上手(纯java project、Maven版本hibernate)

    Hibernate(orm框架)(开放源代码的对象关系映射框架) Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一 ...

  3. 这一次,我连 web.xml 都不要了,纯 Java 搭建 SSM 环境!

    在 Spring Boot 项目中,正常来说是不存在 XML 配置,这是因为 Spring Boot 不推荐使用 XML ,注意,并非不支持,Spring Boot 推荐开发者使用 Java 配置来搭 ...

  4. Spring Boot2 系列教程(一)纯 Java 搭建 SSM 项目

    在 Spring Boot 项目中,正常来说是不存在 XML 配置,这是因为 Spring Boot 不推荐使用 XML ,注意,并非不支持,Spring Boot 推荐开发者使用 Java 配置来搭 ...

  5. Maven构建SpringMVC+Mybatis项目

    1.创建Maven项目时,起始是没有src/main/java.src/test/java.src/test/resources,需要修改一些配置之后,自动就会创建出来: 2.开始引入Spring+M ...

  6. 疑惑的 java.lang.AbstractMethodError: org.mybatis.spring.transaction.SpringManagedTransaction.getTimeout()L

    在MAVEN项目里面,在整合spring和mybatis在执行数据库操作的时候报出了: java.lang.AbstractMethodError: org.mybatis.spring.transa ...

  7. 基于Maven的Springboot+Mybatis+Druid+Swagger2+mybatis-generator框架环境搭建

    基于Maven的Springboot+Mybatis+Druid+Swagger2+mybatis-generator框架环境搭建 前言 最近做回后台开发,重新抓起以前学过的SSM(Spring+Sp ...

  8. 基于纯Java代码的Spring容器和Web容器零配置的思考和实现(3) - 使用配置

    经过<基于纯Java代码的Spring容器和Web容器零配置的思考和实现(1) - 数据源与事务管理>和<基于纯Java代码的Spring容器和Web容器零配置的思考和实现(2) - ...

  9. Cause: java. lang.InstantiationException: tk.mybatis.mapper.provider.base.BaseInsertProvider

    相信现在Java Web开发都是用的mybatis吧,而用到mybatis很多人都不会错过通用mapper吧! (纯属瞎扯淡...qwq). 如我上一篇博客所写,目前公司新项目,使用了通用mapper ...

随机推荐

  1. putty登录显示IP

    登陆服务器 cd vi .bashrc 在尾部加入如下代码 if [ "$SSH_CONNECTION" != '' -a "$TERM" != 'linux' ...

  2. vue:页面跳转和传参(页面之间,父传子,子传父)

    1.返回上一个页面: A.<a @click="$router.back(-1)" class="btn">重新加载</a> B.thi ...

  3. Redis进阶实践之五Redis的高级特性(转载 5)

    Redis进阶实践之五Redis的高级特性 一.引言 上一篇文章写了Redis的特征,使用场景,同时也介绍了Redis的基本数据类型,redis的数据类型是操作redis的基础,这个必须好好的掌握.今 ...

  4. openwrt中防暴力破解shell的脚本

    原文:http://www.right.com.cn/forum/thread-124429-1-1.html 原理:1. snort做入侵检测是很好,但是太大太复杂,我们需要轻量化的操作.当对方进行 ...

  5. android手机 解锁bootloader 刷recovery 线刷rom 卡刷rom

    1 解锁bootloader 为手机安装官方驱动 按相应的组合键使手机进入fastboot模式 执行命令fastboot oem unlock 123456 (123456为厂家提供的解锁码) 手机重 ...

  6. wParam与lParam的区别

    wParam与lParam的区别 lParam 和 wParam 是宏定义,一般在消息函数中带这两个类型的参数,通常用来存储窗口消息的参数. LRESULT CALLBACK WindowProc(H ...

  7. C# 指定平台编译项目

    如CefSharp就需要指定平台,项目为Any CPU时,无法编译,总会提示出错. 如: CefSharp.Common contains unmanaged resoures, set your p ...

  8. 学JS的心路历程-JS支持面向对象?(一)

    昨天在看Prototype看到JS支持面向对象,被前辈问到说那什么是面向对象?JS是面向对象语言吗? 便开始了一连串艰辛爬文过程,今天就来看一下两者有什么差异吧(rgwyjc)! 首先面向对象有三大特 ...

  9. 初识C语言中的函数(男神翁凯老师MOOC)

    什么是函数? 函数是一块代码,接收零个或多个参数,做一件事情,并返回零个或一个值. 可以先想象成数学中的函数: y=f(x) 例如 求begin到end和的函数定义 void sum(int begi ...

  10. JS----事件3

    一 事件对象(event):与特定事件相关且包含有关该事件详细信息的对象通过事件可以触发event对象的元素,鼠标的位置及状态,按下的键等等event对象只在事件发生的过程中才有效非IE浏览器里的ev ...