使用ssm(spring+springMVC+mybatis)创建一个简单的查询实例(一)
梳理下使用spring+springMVC+mybatis 整合后的一个简单实例:输入用户的 ID,之后显示用户的信息(此次由于篇幅问题,会分几次进行说明,此次是工程的创建,逆向生成文件以及这个简单查询工程的流程说明)
源代码在github上可以下载,地址:https://github.com/guoxia0719/ssm-select
工程运行情况如下所示:

输入查询的用户ID:1时,结果为:

数据库中的数据如下所示:

此次会有开发过程中一些常见的问题,都会根据我自己的实例情况给出建议:
开发工具:IDEA, 数据库:MySQL 使用JDK:1.8
主要文件分为以下几个过程:
1.创建整体的项目文件:FIle—>project,

注意按照图片中的步骤创建,也可以不用,后续可以自己进行修改,下一步就是创建名称,输入你自己的组名和项目名称即可,如本次是groupId:com.eightteen, ArtifactId:test01,进行next


上面的步骤完事后,点击next 进行下一步:

这个图片是你具体创建项目的一些信息,确认完成后点击【Finish】即可。
常见完的项目一般如下所示:

项目创建完成后,会缺少一些文件需要你自己补齐,上面的只是针对如何创建项目,下面显示的是这次需要显示的项目,补齐后的文件如下图所示:

上面的文件做下简单的介绍:
jdbc.properties: 主要是关于数据库信息的配置,有驱动类,连接数据库的url,登陆MySQL的用户名和密码
Personal-GeneratorConfig.xml:主要是用于mybatis的逆向工程,用于根据数据库中的表生成对应的实体类,mapper映射文件,以及和映射文件对应的接口文件
spring-mybatis.xml:用于配置spring和mybatis的整合,其中mybatis是持久层框架,配置数据源,实现映射文件和接口文件的管理,可以操作接口文件用于操作MySQL,简化了很多步骤
spring-mvc.xml:用于配置控制层,实现bean的创建和管理,以及自动注解功能开启,视图解析器用于视图的解析
整体流程:
前台传递过来一个url请求,前端控制器接受到这个请求后,会根据这个请求的url去匹配映射(RequestMapping)到具体的业务处理方法,找到业务处理类后会发送给前端控制器handler,
然后交给映射适配器去执行这个handler(这个所谓的handler,其实就是去用于调用具体的业务处理方法的),业务处理方法执行完成后会返回要给ModelAndView给前端控制器。前端控制器会把ModelAndView交给视图解析器进行解析,解析出的View经过渲染后交给前台界面展示给客户。
我这个简单查询的具体流程就是:
在index.jsp文件中输入要查询的用户ID号码,点击查询后,根据映射的url或者说是from表单中的action:/person/select 去匹配映射文件到PersonController类中的getPerson()方法。
这个方法是调用业务的方法,里面通过接口personService文件中的方法去获取具体的信息,PersonServiceImpl类实现了这个接口,PersonServiceImpl这个类中直接使用PersonMapper接口文件去调用具体的处理方法selectByPrimaryKey(id),根据id号码返回要查询的用户信息,其中PersonMapper接口和PersonMapper.xml映射文件是一一对应的,接口中的方法直接对应到映射文件中的SQL ID号码,namespace(对应接口文件的路径)+ID(对应接口文件中的方法名),这些对应关系都是框架自动进行配置的,我们只需要确认这些文件被扫描到即可。
最终能确定唯一的SQL语句,执行结果会根据配置放到具体的对象或结果集中,直接过去即可。

下面开始具体的填补工程中的内容:
1)在MySQL中创建一个表:Person(特别简单,仅是用于梳理流程,实现项目功能),结构图如下所示:

2)根据创建出的表结构,在idea中逆向生成对应的实体类,映射文件和对应的dao层的接口文件,配置如下所示:
?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>
<properties resource="jdbc.properties"></properties>
<classPathEntry location="${jdbc.driverLocation}" />
<!--classPathEntry location="D:\zngkpt\m2\repository\mysql\mysql-connector-java\5.1.40\mysql-connector-java-5.1.40.jar" /-->
<context id="context1" targetRuntime="MyBatis3"> <commentGenerator>
<!-- 去除自动生成的注释 -->
<property name="suppressAllComments" value="true" />
</commentGenerator> <!-- 数据库连接配置 -->
<jdbcConnection driverClass="${jdbc.driverClass}"
connectionURL="${jdbc.connectionURL}"
userId="${jdbc.userId}"
password="${jdbc.password}" />
<!--jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/test"
userId="root"
password="mysql" /--> <!-- 非必需,类型处理器,在数据库类型和java类型之间的转换控制-->
<javaTypeResolver>
<property name="forceBigDecimals" value="false"/>
</javaTypeResolver> <!--配置生成的实体包
targetPackage:生成的实体包位置,默认存放在src目录下
targetProject:目标工程名
-->
<javaModelGenerator targetPackage="com.one.entity"
targetProject="src/main/java" /> <!-- 实体包对应映射文件位置及名称,默认存放在src目录下 -->
<sqlMapGenerator targetPackage="com.one.mapper" targetProject="src/main/java" /> <!-- 接口类生成位置 -->
<javaClientGenerator type="XMLMAPPER" targetPackage="com.one.dao" targetProject="src/main/java"/>
<!-- 配置表
schema:不用填写
tableName: 表名
enableCountByExample、enableSelectByExample、enableDeleteByExample、enableUpdateByExample、selectByExampleQueryId:
去除自动生成的例子
-->
<table schema="" tableName="person" enableCountByExample="false" enableSelectByExample="false"
enableDeleteByExample="false" enableUpdateByExample="false" selectByExampleQueryId="false" >
</table>
</context>
</generatorConfiguration>
其中数据库链接配置文件jdbc.properties
jdbc.driverClass=com.mysql.jdbc.Driver
jdbc.connectionURL=jdbc:mysql://localhost:3306/fis?useUnicode=true&characterEncoding=utf-8
jdbc.userId=root
jdbc.password=rootjdbc.driverLocation=E:\\Java\\MySQL\\mysql-connector-java-5.1.43\\mysql-connector-java-5.1.43\\mysql-connector-java-5.1.43-bin.jar
也可以在配置文件中直接把properties文件中的变量直接写死到Personal-GeneratorConfig.xml 文件中,一般不这么做,不利于维护。
文件配置完成以后,按照下图所示点击菜单栏中的run,选择Edit Configuration,

点击完成以后,出现下图所示:

选择maven之后,会出现下图所示的界面:里面包含已经配置完的信息,最主要的是输入命令:mybatis-generator:generate -e

都配置完成以后,执行下图所示的过程:

以上就是根据表结构生成具体的实体类,映射文件及对应接口文件的过程。还有一种直接配置完后,通过Java文件main方法执行生成文件,这里不再具体叙述。
都执行完以后生成的文件如下所示:

到此,逆向生成文件就结束了,下一篇开始讲解关于里面控制文件,服务文件以及配置文件的说明。
使用ssm(spring+springMVC+mybatis)创建一个简单的查询实例(二)
有什么其他问题,欢迎来一起交流学习!
使用ssm(spring+springMVC+mybatis)创建一个简单的查询实例(一)的更多相关文章
- 使用ssm(spring+springMVC+mybatis)创建一个简单的查询实例(三)(错误整理篇)
使用ssm(spring+springMVC+mybatis)创建一个简单的查询实例(一) 使用ssm(spring+springMVC+mybatis)创建一个简单的查询实例(二) 以上两篇已经把流 ...
- 使用ssm(spring+springMVC+mybatis)创建一个简单的查询实例(二)(代码篇)
这篇是上一篇的延续: 用ssm(spring+springMVC+mybatis)创建一个简单的查询实例(一) 源代码在github上可以下载,地址:https://github.com/guoxia ...
- SSM(Spring + Springmvc + Mybatis)框架面试题
JAVA SSM框架基础面试题https://blog.csdn.net/qq_39031310/article/details/83050192 SSM(Spring + Springmvc + M ...
- SSM(Spring +SpringMVC + Mybatis)框架搭建
SSM(Spring +SpringMVC + Mybatis)框架的搭建 最近通过学习别人博客发表的SSM搭建Demo,尝试去搭建一个简单的SSMDemo---实现的功能是对用户增删改查的操作 参考 ...
- SSM Spring+SpringMVC+mybatis+maven+mysql环境搭建
SSM Spring+SpringMVC+mybatis+maven环境搭建 1.首先右键点击项目区空白处,选择new->other..在弹出框中输入maven,选择Maven Project. ...
- SSM(Spring+SpringMVC+Mybatis)框架环境搭建(整合步骤)(一)
1. 前言 最近在写毕设过程中,重新梳理了一遍SSM框架,特此记录一下. 附上源码:https://gitee.com/niceyoo/jeenotes-ssm 2. 概述 在写代码之前我们先了解一下 ...
- SSM(Spring,SpringMVC,Mybatis)框架整合项目
快速上手SSM(Spring,SpringMVC,Mybatis)框架整合项目 环境要求: IDEA MySQL 8.0.25 Tomcat 9 Maven 3.6 数据库环境: 创建一个存放书籍数据 ...
- SSM Spring +SpringMVC+Mybatis 整合配置 及pom.xml
SSM Spring +SpringMVC+Mybatis 配置 及pom.xml SSM框架(spring+springMVC+Mybatis) pom.xml文件 maven下的ssm整合配置步骤
- SSM:spring+springmvc+mybatis框架中的XML配置文件功能详细解释(转)
原文:https://blog.csdn.net/yijiemamin/article/details/51156189# 这几天一直在整合SSM框架,虽然网上有很多已经整合好的,但是对于里面的配置文 ...
随机推荐
- form提交循环
使用ajax提交数据时,如果数据非常多,提交会比较麻烦,这时可以给form表一个id=“form”,用serializeArray()方法进行提交. erializeArray()方法通过序列化表单值 ...
- DTCC2019第十届中国数据库技术大会将于5月在北京召开
作为国内顶级的数据领域技术盛会,10年来,DTCC见证了国内数据库技术的迅猛发展,各种分布式数据库.NoSQL.NewSQL技术异军突起,与Oracle.DB2等分庭抗礼,甚至大有超越之势.在这种背景 ...
- How do you explain Machine Learning and Data Mining to non Computer Science people?
How do you explain Machine Learning and Data Mining to non Computer Science people? Pararth Shah, ...
- 25个SSH命令
OpenSSH是SSH连接工具的免费版本.telnet,rlogin和ftp用户可能还没意识到他们在互联网上传输的密码是未加密的,但SSH是加密的,OpenSSH加密所有通信(包括密码),有效消除了窃 ...
- C++内存分区:堆、栈、自由存储区、全局/静态存储区和常量存储区
日志 ...
- 玩转spring boot——负载均衡与session共享
前言 当项目上线后,如果要修复bug或扩充功能,都需要重启tomcat服务.此时,正在使用应用的用户们就需要等待服务器的重启,而这就会造成不好的用户体验.还有,当仅仅只有一台tomcat服务时,如果 ...
- Navicate 连接mysql问题
mysql8.0 and Navicate11.2 链接报错问题 亲测有效:记录一下仅供提醒自己 原创: https://blog.csdn.net/xdmfc/article/details/802 ...
- java之代码复用
1.通用查询修改方法 2.通用查询修改方法接口
- Docker Overlay 应用部署
Docker Overlay 部署条件 要想使用Docker原生Overlay网络,需要满足以下任意条件: 1.Docker运行在Swarm模式 2.使用键值存储的Docker主机集群 本次部署使用键 ...
- spring mvc 的上传图片是怎么实现的?
spring mvc 的上传图片是怎么实现的? 导入jar包,commons-io.jar 及 commons-fileupload.jar 在springmvc的配置文件中配置Mutipart解析器 ...