Springboot + netty + rabbitmq + myBatis系列(一) 基础搭建

本文章为 一名Android 小白的 自学 搭建 五天的 总结,肯定会有不对的 或者不规范的地方,如果有 还望指出,本人 迫切需要这方面大佬指点与学习

Github Demo地址

参考文章

1. Sprint Boot 基础搭建

通过 idea 的创建新工程,即可添加spring boot 的工程

1.1 打开idea,左上角File→New→Project,通过弹出框在左侧选择 spring initializr,右侧选择 jdk 版本号,本人为 1.8版本。
1.2 next后 可以 选择 type:maven ,jre :1.8本地版本 。next
1.3 我们选择数据库MySQL和持久层框架MyBatis,next
1.4 选择好项目的目录 我们就可以 点击Finish,开始构建

放一个项目目录
在这里插入图片描述

ThingApplicttion.java 为项目的启动类
application.properties 为项目配置文件
pom.xml 主要描述了项目的maven坐标,依赖关系,项目所需jar包的管理。

2. 配置数据库清单

在application.properties文件中添加如下数据库配置

spring.datasource.url=jdbc:mysql://localhost:3306/(数据库名称)?useSSL=false&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&transformedBitIsBoolean=true&autoReconnect=true&failOverReadOnly=false
spring.datasource.username=(数据库用户名)
spring.datasource.password=(数据库密码)
spring.datasource.driverClassName=com.mysql.jdbc.Driver

3. 创建测试表

CREATE TABLE `user_info` (
  `id` int(32) NOT NULL AUTO_INCREMENT,
  `user_name` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8; 

4. 配置其他包

4.1 model

在根目录下创建model包,创建实体类对象

public class UserInfo {
    /**
     * primary key
     */
    @Id
    private String id;
    /**
     * username
     */
    @Column(name = "user_name")
    private String userName;
    private String password;
    public String getId() {
        return id;
    }
    public void setId(String id) {
        this.id = id;
    }
    public String getUserName() {
        return userName;
    }
    public void setUserName(String userName) {
        this.userName = userName;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
}
4.2 Mapper
<?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.vip.things.dao.UserInfoMapper">
    <resultMap id="BaseResultMap" type="com.vip.things.model.UserInfo">
        <id column="id" jdbcType="INTEGER" property="id"/>
        <result column="user_name" jdbcType="VARCHAR" property="userName"/>
    </resultMap>

    <sql id="Base_Column_List">
        id,user_name
    </sql>

    <select id="selectById" parameterType="java.lang.Integer" resultMap="BaseResultMap">
        select
        <include refid="Base_Column_List"/>
        from user_info
        where id = #{id,jdbcType=VARCHAR}
    </select>

</mapper>

4.3 Dao

在根目录创建 dao 目录,然后创建 dao层文件

public interface UserInfoMapper {

    UserInfo selectById(@Param("id") Integer id);
}
4.4 Service
public interface UserInfoService {

    UserInfo selectById(Integer id);
}

添加Service层 接口实现

@Service
public class UserInfoServiceImpl implements UserInfoService {
    @Resource
    private UserInfoMapper userInfoMapper;
    public UserInfo selectById(Integer id){
        return userInfoMapper.selectById(id);
    }
}
4.5 Controller
@RestController
@RequestMapping("userInfo")
public class UserInfoController {
    @Resource
    private UserInfoService userInfoService;
    @PostMapping("/hello")
    public String hello(){
        return "hello SpringBoot";
    }
    @PostMapping("/selectById")
    public UserInfo selectById(Integer id){
        return userInfoService.selectById(id);
    }
}

Controller中@RestController注解的作用:
@RestController是由@Controller和@ResponseBody组成,表示该类是controller和返回的结果为JSON数据,不是页面路径。

4.6 configurer

在根目录下创建 core.configurer 目录,添加 mapper 配置解析文件

@Configuration
public class MyBatisConfigurer {
    @Bean
    public SqlSessionFactory sqlSessionFactoryBean(DataSource dataSource) throws Exception {
        SqlSessionFactoryBean factory = new SqlSessionFactoryBean();
        factory.setDataSource(dataSource);
        factory.setTypeAliasesPackage("com.vip.things.model");
        // 添加XML目录
        ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
        factory.setMapperLocations(resolver.getResources("classpath:mapper/*.xml"));
        return factory.getObject();
    }

    @Bean
    public MapperScannerConfigurer mapperScannerConfigurer() {
        MapperScannerConfigurer mapperScannerConfigurer = new MapperScannerConfigurer();
        mapperScannerConfigurer.setSqlSessionFactoryBeanName("sqlSessionFactoryBean");
        mapperScannerConfigurer.setBasePackage("com.vip.things.dao");
        return mapperScannerConfigurer;
    }
}

@Configuration表示该文件是一个配置文件
@Bean表示该方法是一个传统xml配置文件中的/Bean id="">"”/Bean>

其中factory.setTypeAliasesPackage(“com.example.demo.model”)表示项目中model的存储路径;

factory.setMapperLocations(resolver.getResources(“classpath:mapper/*.xml”));表示mapper.xml存储路径;

mapperScannerConfigurer.setBasePackage(“com.example.demo.dao”);表示dao层的存储路径
在这里插入图片描述
1:运行
2:调试
3:关闭

通过选择 我们的 启动项 application ,然后 就可以启动了。

我们可以通过 Postman 简单的进行调试

在这里插入图片描述

调试成功,接下来 将会记录 我的第二步开发过程,netty 客户端和 服务端的搭建。如果读者发现那里有问题,还望指出。一起学习进步

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值