idea搭建Spring Boot+Mybatis及使用教程
环境准备
idea 15
jDK
tomcat
maven
搭建方式
- 官网下载源码包解压缩
- 使用idea中的Spring initializr创建
这两种方法创建的项目完全相同,只是操作方式不一样
这里介绍第二种方法,用idea创建
①在idea中,选择File>new Project
出现如下界面
②填写GVN(GroupId,ArtifactctId,Version)(Maven坐标,是用来唯一标识jar包),选择版本
③选择依赖,如下图,勾选Web,Mybatis,MySQL
④填写项目名称,选择项目目录
⑤稍等一会,即可看到项目已下载下来
这里其实项目已经准备好了,但使用还需配置一些参数,下面我们通过一个demo尝试使用它
其它配置
①配置端口号,数据库连接,mybatis等
这些配置我们都集成在一个文件中,我们在项目的src/main/resouces目录下可以找到application.proteries文件,删除该文件,用application.yml配置,这种方式更简洁方便,文件内容如下
server:
# 访问端口号
port: 8080
spring:
datasource:
url: jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=UTC
username: root
password: password
# 使用阿里巴巴的开源框架druid数据库连接池
type: com.alibaba.druid.pool.DruidDataSource
platform: mysql
# mysql 8.0.+使用的驱动
driver-class-name: com.mysql.cj.jdbc.Driver
filters: stat
maxActive: 20
initialSize: 1
maxWait: 60000
minIdle: 1
timeBetweenEvictionRunsMillis: 60000
minEvictableIdleTimeMillis: 300000
validationQuery: select 'x'
testWhileIdle: true
testOnBorrow: false
testOnReturn: false
poolPreparedStatements: true
maxOpenPreparedStatements: 20
mybatis:
# mapper映射文件地址,这里我在src/main/resouces下新建文件夹mapper
mapper-locations: classpath*:mapper/*.xml
# 配置bean扫描目录,也可用注解
type-aliases-package: classpath*:com.example.demo.entity
② 配置pom文件
pom文件中描述了maven管理的包等,上面我们用到了Druid作为数据库连接池,所以我们需要在pom.xml中的
<dependencies>...</dependencies>
中添加如下代码
<!-- alibaba的druid数据库连接池 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.1.0</version>
</dependency>
这样jar包就引进来了
编写程序
① 在数据库新建一张表user,属性如下(自己填写数据)
② User.java
src/main/java/com.example.demo/entity/User.java
目录需自己创建,下面步骤同理
public class User {
private Integer id;
private String name;
private String sex;
private Integer age ;
// set** and get** 方法省略,自己写
}
③ UserMapper.java
src/main/java/com.example.demo/mapper/UserMapper.java
@Mapper //声明是一个Mapper,与springbootApplication中的@MapperScan二选一写上即可
@Repository
public interface UserMapper {
List<User> getAllUser();
}
④ UserMapper.xml
src/main/resouces/mapper/UserMaper.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="com.example.demo.mapper.UserMapper">
<select id="getAllUser" resultType="com.example.demo.entity.User">
SELECT * FROM user
</select>
</mapper>
⑤ UserService.java
src/main/java/com.example.demo/service/UserService.java
public interface UserService {
List<User> getAllUser();
}
⑥ UserServiceImpl.java
src/main/java/com.example.demo/service/impl/UserServiceImpl.java
@Service(value = "userService")
public class UserServiceImpl implements UserService {
@Resource
private UserMapper userMapper;
@Override
public List<User> getAllUser() {
return userMapper.getAllUser();
}
}
⑦ UserController.java
src/main/java/com.example.demo/controller/UserController.java
@Controller
@RequestMapping(value = "/user")
public class UserController {
@Autowired
private UserService userService;
@RequestMapping("/getAllUser")
@ResponseBody
private List<User> getAllUser() {
List<User> users = userService.getAllUser();
return users;
}
}
⑧ DemoApplication.java
src/main/java/com.example.demo/DemoApplication.java
注意该文件已存在,替换或修改
@SpringBootApplication
@EnableTransactionManagement //开启事务管理
@ComponentScan("com.example.demo")
//@MapperScan("com.example.demo.mapper")//与dao层的@Mapper二选一写上即可(主要作用是扫包)
public class DemoApplication {
public static void main(String[] args) {
SpringApplication.run(DemoApplication.class, args);
}
@Bean(destroyMethod = "close", initMethod = "init")
@ConfigurationProperties(prefix = "spring.datasource")
public DruidDataSource druidDataSource() {
DruidDataSource druidDataSource = new DruidDataSource();
return druidDataSource;
}
}
这里是目录结构图
测试
1.运行DemoApplication.java,出现如下界面则成功
2.在浏览器输入127.0.0.1:8080/user/getAllUser
成功!
这里返回的是数据,如果你想要建立一个web项目,使用网页来与用户交互,也很简单,请继续浏览下面的内容。
Spring Boot 开发Web项目
使用模板引擎Thymeleaf
① 引入模板引擎
在pom.xml文件中
<dependencies>...</dependencies>
模块中添加如下依赖
<!-- 使用thymeleaf模板引擎 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
② 添加访问控制器
在上面建立的UserController类中添加方法
@RequestMapping("/list")
public String listUser(Model model) {
List<User> userList = getAllUser();
model.addAttribute("users", userList);
return "user/list";
}
由于该类有
@RequestMapping(value = "/user")
注解,所以此方法访问路径为
http://localhost:8080/user/list
③ 添加显示页面list.html
在
src\main\resources\templates
目录下新建user目录,再新建文件list.html
。文件内容如下:
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<meta charset="UTF-8" />
<title>Insert title here</title>
</head>
<body>
<h2>用户列表</h2>
<div>
<ul>
<li th:each="user:${users}">id-
<span th:text="${user.id}"></span>: 姓名
<span th:text="${user.name}"></span>年龄
<span th:text="${user.age}"></span>性别
<span th:text="${user.sex}"></span>
</li>
</ul>
</div>
</body>
</html>
我的idea报错了,在user上有红线,但可以运行,其中执行过程为
1.访问网址为localhost:8080/user/list
2.执行UserController中的listUser(Model model)方法
3.该方法返回值是"/user/list"
4.由于模板引擎Thymeleaf默认配置将页面放在resources\templates目录下(可配置)
5.所以浏览器返回resources\templates\user\list.html页面,数据已放入model中
这样Spring Boot就成功将数据显示在web页面
事实上你现在就可以将该项目部署到服务器,请参考我的另一篇博文:Spring Boot 打包jar部署服务器
结束语:本文为实时学习记录,是小白,若有错误或不足之处,非常抱歉!
idea搭建Spring Boot+Mybatis及使用教程的更多相关文章
- myEclipse 搭建 Spring boot+myBatis+maven 项目流程
1.新建一个工程 new-->maven project-->next-->next-->在filter中搜索webapp-->group id.Artifact id- ...
- idea搭建Spring Boot+MyBatis
需要准备的环境: idea 2017.2 jdk1.8.0_144 Maven 3.5.0 请提前将idea与Maven.jdk配置好,本次项目用的都是比较新的. 步骤: 一.首先使用idea新建一个 ...
- spring boot+mybatis+quartz项目的搭建完整版
1. 利用spring boot提供的工具(http://start.spring.io/)自动生成一个标准的spring boot项目架构 2. 因为这里我们是搭建spring boot+mybat ...
- Spring boot+Mybatis+MySQL插入中文乱码
转载:https://www.jianshu.com/p/bd0311a33c16 现象: 搭建spring boot+mybatis+mysql时出现插入mysql的中文出现乱码???. mys ...
- Spring Boot入门教程2-1、使用Spring Boot+MyBatis访问数据库(CURD)注解版
一.前言 什么是MyBatis?MyBatis是目前Java平台最为流行的ORM框架https://baike.baidu.com/item/MyBatis/2824918 本篇开发环境1.操作系统: ...
- 快速搭建一个Spring Boot + MyBatis的开发框架
前言:Spring Boot的自动化配置确实非常强大,为了方便大家把项目迁移到Spring Boot,特意总结了一下如何快速搭建一个Spring Boot + MyBatis的简易文档,下面是简单的步 ...
- java 搭建新项目,最佳组合:spring boot + mybatis generator
java 搭建新项目,最佳组合:spring boot + mybatis generator
- Spring Boot 2.x基础教程:使用MyBatis的XML配置方式
上一篇我们介绍了如何在Spring Boot中整合我们国人最常用的MyBatis来实现对关系型数据库的访问.但是上一篇中使用了注解方式来实现,而对于很多MyBatis老用户还是习惯于XML的开发方式, ...
- spring boot+mybatis搭建项目
一.创建spring boot项目 1.File->New->Project 2.选择 Spring Initializr ,然后选择默认的 url 点击[Next]: 3.修改项目信息 ...
随机推荐
- “全栈2019”Java异常第十一章:重写方法时只能抛出父类异常子集
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java异 ...
- jmeter - jp@gc - Active Threads Over Time(多台负载用户)
问题: 线程数设置:30,远程启动2台机子 查看 jp@gc - Active Threads Over Time图,发现只统计了1台机子的线程数,线程数并不是60: 解决办法: 官方文档中提到: 1 ...
- Python标准库中的生成器函数
一.用于过滤的生成器函数 - 从输入的可迭代对象中产出元素的子集,而不修改元素本身 import itertools l1 = [1,2,3,4,5] l2 = [True,False,True,Fa ...
- CUDA安装
1.CUDA是什么? CUDA(Compute Unified Device Architecture),显卡厂商NVidia推出的运算平台. 随着显卡的发展,GPU越来越强大,而且GPU为显示图像做 ...
- QuantLib 金融计算——随机过程之概述
目录 QuantLib 金融计算--随机过程之概述 框架 用法与接口 如果未做特别说明,文中的程序都是 Python3 代码. QuantLib 金融计算--随机过程之概述 载入模块 import Q ...
- js继承(自备水,这非常干货)
讲js继承之前,想一想什么是继承? 生活中有很多例子,比方说继承财产,继承女朋友的前男友的前女友 ヽ(ー_ー)ノ ,这些和js继承差不多,但是有一个不一样的地方,就是继承过后,原先的人就没有了,js继 ...
- [性能测试]:关于消费类ISO8583协议脚本的开发
一,要发送的报文,转化成16进制的,报文如下 "\x01\x52"//报文长度338 "\x60\x00\x24\x00\x00"//TPDU "\x ...
- 查看Postgresql的连接状况
今天遇到一个问题,就是pg一直报错,说有太多的客户端连接到数据库上面.但现在不知道是什么程序连接.pg默认的max_connection是100,我并没有修改过,以为平时公司内部用,应该够了,但现在貌 ...
- DB2 close auto commit
db2 关闭命令行CLP自动提交 --临时关闭自动提交 #db2 "update command options using C off --永久关闭自动提交 ----linux 环境下 # ...
- 【Kafka】Kafka集群搭建
一.准备工作 服务器:最好是多台,大于等于2 已经搭建好的zookeeper集群 下载软件kafka_2.11-0.10.0.1.tgz 二.创建目录 #创建目录 cd /opt/ mkdir kaf ...