spring boot + mysql8+ +mybatis + myabtis-generator全套流程

安装mysql8+

1.安装mysql8+,从mysql官网下载最新的mysql安装包。
2.安装好之后,把mysql加入到环境变量中:
		vim .bash_profile
		在文件中加入下列语句:
		export PATH=${PATH}:/usr/local/mysql/bin
		保存,退出终端。
3. 打开新的终端
 输入mysql -u root -p 登录,会出现错误,root用户的密码没有设置。
     解决的方法:
	 1、苹果->系统偏好设置->关闭mysql服务(点击stop mysql server)
	 2、进入终端输入:cd /usr/local/mysql/bin/
	 3、回车后 登录管理员权限sudo su
	 4、回车后输入以下命令来禁止mysql验证功能./mysqld_safe --skip-grant-tables &
	 5、输入命令 ./mysql
	 	#先创建一个用户
	 6、create user 'je'@'%' identified by '123456';
	 	#再进行授权
	 7、grant all privileges on *.* to 'je'@'%' with grant option;
	 8、exit退出数据库
4. 创建数据库实例
 	1.使用je用户登录数据库:mysql -u je -p
 	2.创建实例:CREATE DATABASE doghouse;
 	3.exit退出
5.使用客户端理解,使用了DBeaver的直接在创建连接的时候,选择Mysql8+

填写host:localhost,用户名,密码,端口不用更改。

在这里插入图片描述

spring boot项目中配置mybatis

1. 在application.properties中配置如下信息:

  spring.datasource.url=jdbc:mysql://localhost:3306/doghouse?			    useSSL=false&serverTimezone=Asia/Shanghai&characterEncoding=utf-8&autoReconnect=true
  spring.datasource.username=je
  spring.datasource.password=123456
  spring.datasource.driver-class-name=com.mysql.cj.jdbc.Drive
  mybatis.mapperLocations=classpath:mappers/*Mapper.xml
  mybatis.typeAliasesPackage=com.example.demo.bean
 





其中特别需要注意的是:
	1、useSSL=false&serverTimezone=Asia/Shanghai&characterEncoding=utf-8&autoReconnect=true
	这个要显示的指定userSSL为false,不使用ssl方式连接mysql。serverTimezone指定时区。
	2、driver-class-name 为com.mysql.cj.jdbc.Driver。
2. 在pom.xml文件加入mybatis-generator的相关引入

<plugin>
	<groupId>org.mybatis.generator</groupId>
	<artifactId>mybatis-generator-maven-plugin</artifactId>
	<configuration>
		<overwrite>true</overwrite>
		<verbose>true</verbose>
	</configuration>
	<dependencies>
		<dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
			<version>8.0.16</version>
		</dependency>
	</dependencies>
</plugin>
3. 在项目中的resource目录下增加mybatis-generator的配置

1、在目录下新建两个文件:datasource.properties和generatorConfig.xml
在这里插入图片描述
2、在generatorConfig.xml中配置;其中涉及到的目录要先创建好,mapper目录,bean目录

<?xml version="1.0" encoding="UTF-8"?>
<!-- 指定数据库驱动的jdbc驱动jar包的位置 -->
<!--<classPathEntry location="${db.driverLocation}" />-->

<!-- context 是逆向工程的主要配置信息 -->
<!-- id:起个名字 -->
<!-- targetRuntime:设置生成的文件适用于那个 mybatis 版本 -->
<context id="default" targetRuntime="MyBatis3">

    <!--optional,旨在创建class时,对注释进行控制-->
    <commentGenerator>
        <property name="suppressDate" value="true" />
        <!-- 是否去除自动生成的注释 true:是 : false:否 -->
        <property name="suppressAllComments" value="true" />
    </commentGenerator>

    <!--jdbc的数据库连接-->
    <jdbcConnection driverClass="${db.driverClassName}"
                    connectionURL="${db.url}"
                    userId="${db.username}"
                    password="${db.password}">
    </jdbcConnection>

    <!--非必须,类型处理器,在数据库类型和java类型之间的转换控制-->
    <javaTypeResolver>
        <!-- 默认情况下数据库中的 decimal,bigInt 在 Java 对应是 sql 下的 BigDecimal 类 -->
        <!-- 不是 double 和 long 类型 -->
        <!-- 使用常用的基本类型代替 sql 包下的引用类型 -->
        <property name="forceBigDecimals" value="false" />
    </javaTypeResolver>

    <!-- targetPackage:生成的实体类所在的包 -->
    <!-- targetProject:生成的实体类所在的硬盘位置 -->
    <javaModelGenerator targetPackage="com.example.demo.bean"
                        targetProject="src/main/java">
        <!-- 是否允许子包 -->
        <property name="enableSubPackages" value="false" />
        <!-- 是否对modal添加构造函数 -->
        <property name="constructorBased" value="true" />
        <!-- 是否清理从数据库中查询出的字符串左右两边的空白字符 -->
        <property name="trimStrings" value="true" />
        <!-- 建立modal对象是否不可改变 即生成的modal对象不会有setter方法,只有构造方法 -->
        <property name="immutable" value="false" />
    </javaModelGenerator>

    <!-- targetPackage 和 targetProject:生成的 mapper 文件的包和位置 -->
    <sqlMapGenerator targetPackage="mappers"
                     targetProject="src/main/resources">
        <!-- 针对数据库的一个配置,是否把 schema 作为字包名 -->
        <property name="enableSubPackages" value="false" />
    </sqlMapGenerator>

    <!-- targetPackage 和 targetProject:生成的 interface 文件的包和位置 -->
    <javaClientGenerator type="XMLMAPPER"
                         targetPackage="com.example.demo.mapper" targetProject="src/main/java">
        <!-- 针对 oracle 数据库的一个配置,是否把 schema 作为字包名 -->
        <property name="enableSubPackages" value="false" />
    </javaClientGenerator>
    <table tableName="login_user" domainObjectName="LoginUser"
           enableCountByExample="false" enableUpdateByExample="false"
           enableDeleteByExample="false" enableSelectByExample="false"
           selectByExampleQueryId="false">
    </table>
</context>

3、在datasource.properties中增加数据库配置


db.driverLocation=/mysql-connector-java-8.0.16/mysql-connector-java-8.0.16.jar
db.driverClassName=com.mysql.cj.jdbc.Driver
db.url=jdbc:mysql://localhost:3306/doghouse?useSSL=false&serverTimezone=Asia/Shanghai&characterEncoding=utf-8&autoReconnect=true
db.username=je
db.password=123456

4、点击maven中的generator,自动生成mapper, entity, xml文件
在这里插入图片描述

以上是正常流程,在安装和配置的过程中会出现各种问题:

1. 数据库权限,客户端登录要授予远程登录的权限

grant all privileges on . to ‘je’@’%’ with grant option;

2. mysql8+与之前版本有密码加密方式的不同,若果使用navicat要更改数据库的加密方式
3. 项目中配置的driverclassname 要更改名称, url中要增加useSSL和serverTimezone
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值