• 使用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:zngkptm2
    epositorymysqlmysql-connector-java5.1.40mysql-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)创建一个简单的查询实例(二)

    有什么其他问题,欢迎来一起交流学习!

    
    
    
  • 相关阅读:
    0426-mysql插入语句大全
    JS节点操作
    模态框
    滚动监听 after选择器
    JS数组
    js函数 DOM操作
    JS循环 for while 全局/局部变量 短路
    JavaScript 基础 if switch 弹窗 运算符
    无序列表属性 隐藏方式 JS简介
    Css问题 margin float 文档流 背景图底部充满
  • 原文地址:https://www.cnblogs.com/guopengxia0719/p/10552862.html
Copyright © 2020-2023  润新知