Springboot & Mybatis 构建restful 服务
Springboot & Mybatis 构建restful 服务一
1 前置条件
jdk测试:java -version
maven测试:命令行之行mvn -v
eclipse及maven插件
2 Springboot
1)创建maven项目:
eclipse:new -> project -> maven project
选择:Create a simple project(skip archetype selection)
(假设项目名为com.serena.AccountBalance)
2)修改pom:
<!-- 新增 -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.4.1.RELEASE</version>
</parent>
<dependencies>
<!-- 新增spring boot依赖 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
3)下载数据库驱动包(此例使用的是 Oracle 数据库,由于 Oracle 版权问题,所以需下载驱动jar包):
去 Oracle 官网下载 jdbc驱动ojdbc6-1.0.1.jar
在终端执行下列命令
mvn install:install-file -DgroupId=com.oracle -DartifactId=ojdbc6 -Dversion=1.0.1 -Dpackaging=jar -Dfile=ojdbc6.jar
在eclipse中选中当前工程
maven -> update project...
4)在项目目录下分别创建:
(此例中为:main/java/com/serena)
— controller //接口层
— servcie //业务层
— impl
— mapper //数据操作层
— entity //数据持久化层
5)在项目目录下新建启动类 App.java:
(此例中为:main/java/com/serena)
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class App {
public static void main(String[] args) {
SpringApplication.run(App.class, args);
}
}
6)代码:编写controller和service代码
创建service/ISY.java,内容如下:
package com.serena.service;
import java.util.List;
import com.serena.entity.SettleAccount;
public interface ISY {
// 通过账户 id(主键)查找账户
SettleAccount selectByAccountCode(String accountCode);
// 查找所有账户
List<SettleAccount> selectAccounts();
}
创建 controller/SY.java,内容如下:
package com.serena.controller;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;
import com.serena.entity.SettleAccount;
import com.serena.service.ISY;
@RestController
public class SY {
@Autowired
private ISY iSY;
// 通过用户 id 来查找用户余额
// 使用 get 请求传递参数
@RequestMapping(value="/account/{accountCode}",method = RequestMethod.GET)
public SettleAccount selectByAccountCode(@PathVariable("accountCode")String accountCode){
SettleAccount settleAccount = iSY.selectByAccountCode(accountCode);
return settleAccount;
}
// 查找所有 account 的余额
@RequestMapping(value="/accounts",method = RequestMethod.GET)
public List<SettleAccount> selectAccounts(){
List<SettleAccount> list = null;
list = iSY.selectAccounts();
return list;
}
}
编写service/impl/SYService.java
package com.serena.service.impl;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.serena.entity.SettleAccount;
import com.serena.mapper.SettleAccountMapper;
import com.serena.service.ISY;
@Service
public class SYService implements ISY{
@Autowired
private SettleAccountMapper settleAccountMapper;
@Override
public SettleAccount selectByAccountCode(String accountCode) {
SettleAccount settleAccount = null;
settleAccount = settleAccountMapper.selectByPrimaryKey(accountCode);
return settleAccount;
}
@Override
public List<SettleAccount> selectAccounts() {
List<SettleAccount> list = null;
list = settleAccountMapper.selectAccounts();
return list;
}
}
3 Mybatis generator
1)修改pom:
新增依赖
<!-- Spring Boot 集成MyBatis -->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.1.1</version>
</dependency>
<!-- 实体映射 -->
<dependency>
<groupId>com.datastax.cassandra</groupId>
<artifactId>cassandra-driver-mapping</artifactId>
</dependency>
<!-- mysql 数据库连接 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>
<!-- oracle 数据库连接 -->
<dependency>
<groupId>com.oracle</groupId>
<artifactId>ojdbc6</artifactId>
<version>1.0.1</version>
<scope>runtime</scope>
</dependency>
新增自动生成 mapper 和 entity 插件 plugin
<!-- mybatis generator 插件 -->
<plugin>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-maven-plugin</artifactId>
<version>1.3.5</version>
<configuration>
<verbose>true</verbose>
<overwrite>true</overwrite>
</configuration>
</plugin>
2)创建配置文件: src/main/resources/generatorConfig.xml
中文标注的地方需自定义!!!
<!DOCTYPE generatorConfiguration
PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
<classPathEntry location="安装的 Oracle 驱动包的仓库jar文件位置" />
<context id="OracleTables" targetRuntime="MyBatis3">
<commentGenerator>
<property name="suppressAllComments" value="true"/>
</commentGenerator>
<jdbcConnection driverClass="驱动类"
connectionURL="数据库URL地址"
userId="用户名" password="密码">
</jdbcConnection>
<javaTypeResolver>
<property name="forceBigDecimals" value="false"/>
</javaTypeResolver>
<javaModelGenerator targetPackage="com.serena.entity" targetProject="src/main/java">
<property name="enableSubPackages" value="false"/>
<property name="trimStrings" value="true"/>
</javaModelGenerator>
<sqlMapGenerator targetPackage="com.serena.mapper" targetProject="src/main/java">
<property name="enableSubPackages" value="false"/>
</sqlMapGenerator>
<javaClientGenerator type="XMLMAPPER" targetPackage="com.serena.mapper" targetProject="src/main/java">
<property name="enableSubPackages" value="false"/>
</javaClientGenerator>
<!-- 例: 查询的表名:SETTLEACCOUNT
自定义的实体类名称:SettleAccount
-->
<table tableName="SETTLEACCOUNT" domainObjectName="自定义的实体类名称" enableCountByExample="false" enableSelectByExample="false" enableUpdateByExample="false" enableDeleteByExample="false">
</table>
</context>
</generatorConfiguration>
3) 执行:maven build: mybatis-generator:generate
4. Mybatis
1) 在所有mapper类中的接口声明前增加 @Mapper
添加@Mapper
@Mapper
public interface SettleAccountMapper {
//some code
}
2)删除entity 里SettleAccount多余的属性和 setter,getter 方法,只保留 ACCOUNTCODE, CUSTOMERCODE, ACCOUNTNAME, SMSNUM
3)在SettleAccountMapper.xml中执行下列操作:
// 添加
<select id="selectAccounts" resultMap="BaseResultMap">
select
<include refid="Base_Column_List" />
from SETTLEACCOUNT
</select>
// 修改 id为BaseResultMap的resultMap
<resultMap id="BaseResultMap" type="com.serena.entity.SettleAccount">
<id column="ACCOUNTCODE" jdbcType="VARCHAR" property="accountcode" />
<result column="CUSTOMERCODE" jdbcType="VARCHAR" property="customercode" />
<result column="ACCOUNTNAME" jdbcType="VARCHAR" property="accountname" />
<result column="SMSNUM" jdbcType="DECIMAL" property="smsnum" />
</resultMap>
// 修改id 为Base_Column_List的 sql
<sql id="Base_Column_List">
ACCOUNTCODE, CUSTOMERCODE, ACCOUNTNAME, SMSNUM
</sql>
修改SettleAccountMapper:
package com.serena.mapper;
import java.util.List;
import org.apache.ibatis.annotations.Mapper;
import com.serena.entity.SettleAccount;
@Mapper
public interface SettleAccountMapper {
// 抽象方法:通过账户编号查找账户
SettleAccount selectByPrimaryKey(String accountcode);
// 抽象方法:查找所有账户
List<SettleAccount> selectAccounts();
}
4)编译:maven build: clean compile
5)创建配置文件:src/main/java/resources/application.properties
// 服务器端口号
server.port=8101
// mapper映射地址
mybatis.mapper-locations=classpath*:mapper/*Mapper.xml
// 数据库URL地址
spring.datasource.url=
// 登录数据库的用户名
spring.datasource.username=
// 密码
spring.datasource.password=
6)运行启动类App.class
7)在iterm 中输入如下指令测试:
http localhost:8101/accounts
http localhost:8101/account/U0001
Springboot & Mybatis 构建restful 服务的更多相关文章
- Springboot & Mybatis 构建restful 服务五
Springboot & Mybatis 构建restful 服务五 1 前置条件 成功执行完Springboot & Mybatis 构建restful 服务四 2 restful ...
- Springboot & Mybatis 构建restful 服务四
Springboot & Mybatis 构建restful 服务四 1 前置条件 成功执行完Springboot & Mybatis 构建restful 服务三 2 restful ...
- Springboot & Mybatis 构建restful 服务三
Springboot & Mybatis 构建restful 服务三 1 前置条件 成功执行完Springboot & Mybatis 构建restful 服务二 2 restful ...
- Springboot & Mybatis 构建restful 服务二
Springboot & Mybatis 构建restful 服务二 1 前置条件 成功执行完Springboot & Mybatis 构建restful 服务一 2 restful ...
- 基于SpringBoot开发一个Restful服务,实现增删改查功能
前言 在去年的时候,在各种渠道中略微的了解了SpringBoot,在开发web项目的时候是如何的方便.快捷.但是当时并没有认真的去学习下,毕竟感觉自己在Struts和SpringMVC都用得不太熟练. ...
- jersey+maven构建restful服务
一.新建一个Maven Web项目 a) 新建一个简单的Maven项目 b) 将简单的Maven项目转成Web项目 (若没出现further configuration available--或里面的 ...
- 用Jersey构建RESTful服务7--Jersey+SQLServer+Hibernate4.3+Spring3.2
一.整体说明 本例执行演示了用 Jersey 构建 RESTful 服务中.怎样集成 Spring3 二.环境 1.上文的项目RestDemo 2.Spring及其它相关的jar ,导入项目 三.配置 ...
- JAX-RS(基于Jersey) + Spring 4.x + MyBatis构建REST服务架构
0. 大背景 众所周知,REST架构已经成为现代服务端的趋势. 很多公司,已经采用REST作为App, H5以及其它客户端的服务端架构. 1. 什么是JAX-RS? JAX-RS是JAVA EE6 引 ...
- CXF+Spring+JAXB+Json构建Restful服务
话不多说,先看详细的样例: 文件文件夹结构: web.xml <?xml version="1.0" encoding="UTF-8"? > < ...
随机推荐
- 一条SQL语句执行得很慢的原因有哪些?
说实话,这个问题可以涉及到 MySQL 的很多核心知识,可以扯出一大堆,就像要考你计算机网络的知识时,问你“输入URL回车之后,究竟发生了什么”一样,看看你能说出多少了. 之前腾讯面试的实话,也问到这 ...
- 盘点一下Github上开源的Java面试/学习相关的仓库,看完弄懂薪资至少增加10k
最近浏览 Github ,收藏了一些还算不错的 Java面试/学习相关的仓库,分享给大家,希望对你有帮助.我暂且按照目前的 Star 数量来排序. 本文由 SnailClimb 整理,如需转载请联系作 ...
- Python序列化操作与反序列操作
一.概念 序列化:转向一个字符串数据类型序列:字符串 二.需要做序列化操作的情况1.数据存储2.网络上数据传输 从数据类型到字符串的过程叫序列化从字符串到数据类型的过程叫反序列化 三.现有序列化模块1 ...
- IDEA中使用中jetty启动java项目(非springboot)
1.安装maven helper插件,略 2.项目pom.xml文件中添加jetty插件配置 <build> <plugins> <plugin> <grou ...
- form表单中$_FILES数组的使用
<form enctype="multipart/form-data" action="upload.php" method="post&quo ...
- liteUploader上传控件的封装使用
//原来的绑定方式 $('#' + frm_name).liteUploader({ script: url, params: { type: "image", size: siz ...
- Oracle主从同步、双向同步的配置
(本教程展示了Windows环境的oracle数据库主从同步,Linux环境一样也可以) (把主数据库obpm 和从数据库orcl 用实际的数据库名给替换掉) (配置主从同步后,再配置双向同步,可能会 ...
- 布署配置管理中心apollo
Apollo(阿波罗)是携程框架部门研发的分布式配置中心,能够集中化管理应用不同环境.不同集群的配置,配置修改后能够实时推送到应用端,并且具备规范的权限.流程治理等特性,适用于微服务配置管理场景. 服 ...
- springboot+maven整合spring security
springboot+maven整合spring security已经做了两次了,然而还是不太熟悉,这里针对后台简单记录一下需要做哪些事情,具体的步骤怎么操作网上都有,不再赘述.1.pom.xml中添 ...
- git 免密码push
git版本2.14.1 windows系统 用户根目录 .gitconfig 文件添加配置 [credential] helper = store[push] default = simple 用户根 ...