spring boot+mybaits+mysql+generato(逆向工程)+前后台数据交互
如按照我博客上没有弄出来 请在下面留言 我好修改 谢谢
小弟使用的是 Eclipse 首先下载 STS 插件 help--->Elipse Marketplace--->find 搜索栏里面搜索 STS 然后安装。 如下图
然后 在安装一个 mybaits 的插件
安装完后 new --->New Project--> 如下图
然后 -->Next 会出现下图
跟 maven 项目一样。写好点击 Nex 出现下图
点击 Web 把 web 勾上 如下图
在选择 SQL 把 mysql 和 mybatis 勾上 如下图
然后 Next 然后 filsh
一个 spring boot 项目就搭建好了,现在进入 generato(逆向工程) 环节
首先在 src/main/java 把 MVC 结构目录建好 入下图
然后 在 src/main/resources 下面建立一个 generatorConfig.xml 文件 文件类容如下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 | <?xml version= "1.0" encoding= "UTF-8" ?> <!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= "C:\Users\Administrator\.m2\repository\mysql\mysql-connector-java\5.1.46\mysql-connector-java-5.1.46.jar" /> <context id= "Tables" targetRuntime= "MyBatis3" > <!-- 注释 --> <commentGenerator> <!-- 是否生成注释代时间戳 --> <property name= "suppressDate" value= "true" /> <!-- 是否去除自动生成的注释 true :是 : false :否 --> <property name= "suppressAllComments" value= "true" /> </commentGenerator> <!-- JDBC连接 其中connectionURL后面的test改为你创建的数据库,紧跟在后面是数据库连接的账户和密码--> <jdbcConnection driverClass= "com.mysql.jdbc.Driver" connectionURL= "jdbc:mysql://localhost:3306/test" userId= "root" password= "root" > </jdbcConnection> <!-- 非必需,类型处理器,在数据库类型和java类型之间的转换控制--> <!-- 默认 false ,把JDBC DECIMAL 和 NUMERIC 类型解析为 Integer,为 true 时把JDBC DECIMAL 和 NUMERIC 类型解析为java.math.BigDecimal --> <javaTypeResolver> <!-- 是否使用bigDecimal, false 可自动转化以下类型(Long, Integer, Short, etc.) --> <property name= "forceBigDecimals" value= "false" /> </javaTypeResolver> <!-- 生成实体类地址 这里需要你改动,其中targetPackage需要根据你自己创建的目录进行改动 --> <javaModelGenerator targetPackage= "com.wwjc.pojo" targetProject= "springBoot-mybatis-test-1/src/main/java" > <!-- 从数据库返回的值被清理前后的空格 --> <property name= "trimStrings" value= "true" /> <!-- enableSubPackages:是否让schema作为包的后缀 --> <property name= "enableSubPackages" value= "false" /> </javaModelGenerator> <!-- 生成mapper xml文件 这里不需要改动 --> <sqlMapGenerator targetPackage= "mapper" targetProject= "springBoot-mybatis-test-1/src/main/resources" > <!-- enableSubPackages:是否让schema作为包的后缀 --> <property name= "enableSubPackages" value= "false" /> </sqlMapGenerator> <!-- 生成dao 这里需要改动targetPackage,依据你自己的工程--> <javaClientGenerator targetPackage= "com.wwjc.dao" targetProject= "springBoot-mybatis-test-1/src/main/java" type= "XMLMAPPER" > <!-- enableSubPackages:是否让schema作为包的后缀 --> <property name= "enableSubPackages" value= "false" /> </javaClientGenerator> <!-- 配置表信息 --> <!-- schema即为数据库名 tableName为对应的数据库表 domainObjectName是要生成的实体类 enable*ByExample 是否生成 example类 --> <table schema= "test" tableName= "student" domainObjectName= "Student" enableCountByExample= "true" enableDeleteByExample= "true" enableSelectByExample= "true" enableUpdateByExample= "true" > </table> </context> </generatorConfiguration> |
写好后 然后 如下图操作 点击 Run MyBatis Generator
就会执行逆向工程 然后就有了 如下图
然后在 resources 下面修改 application.properties 文件里面的信息 如下图
dao 层的接口一定要打上 @Mapper 注解 不然会报注入失败异常
dao 层写一个方法
然后在 resouresc 下的 xml 文件里面写 sql 语句
id 对应你 dao 层 Mapper 接口里写的方法名 一定要一致 不然启动会报注入失败或者其他异常
resultMap 好像只能写这个 我写返回类型 会查不出数据 resultMap 就没有问题
service 接口层 如下图
实现类
controller 层 如下图
然后启动带 Application 这个名字的类
然后 输入下图地址测试
其他的删除,新增,修改都是一样的
显示佛祖 在 resources 下面添加一个 banner.txt 然后里面代码如下
在控制台打印 sql 语句 则在 application.properties 里面添加一句
level.com.xx. 你的 dao 层 =DEBUG 就可以了 效果如下图
打印了执行的 sql 语句
前台页面放在 下图位置
index.html 类容下图
JS 如下
启动项目 访问 index 页面 输入下图地址
页面放在静态资源区里面 所以访问可以再 8080 后面直接 /html/index.html
然后点击 数据测试 得到的效果如下图
后天传回一个渣渣辉 并显示到页面上
数据库 如下图
如有问题请在下面留言