目录

  • 1 2023广东省精品课程评审申报章节
    • 1.1 申报书
    • 1.2 总结报告
    • 1.3 课程数据信息表
    • 1.4 自评报告
    • 1.5 专家组评语
    • 1.6 相关佐证
  • 2 2020校精品课程评审申报章节
    • 2.1 验收材料总文档
    • 2.2 精品开放课程申报书
    • 2.3 精品开放课程结题验收报告书
    • 2.4 精品开放课程结题验收总结报告
    • 2.5 精品开放课程结题验收项目汇总表
    • 2.6 佐证1.课程基础与建设目标
      • 2.6.1 校本教材
      • 2.6.2 论文
    • 2.7 佐证2.课程设计
      • 2.7.1 课程定位
      • 2.7.2 建设方式
    • 2.8 佐证3.更新与共享
      • 2.8.1 吸引力
      • 2.8.2 内容更新
      • 2.8.3 媒体应用
    • 2.9 佐证4.教学团队
      • 2.9.1 负责人
      • 2.9.2 教学队伍
    • 2.10 佐证5.教学资源
      • 2.10.1 基本资源
        • 2.10.1.1 单元设计
        • 2.10.1.2 课件PPT
        • 2.10.1.3 授课视频
      • 2.10.2 拓展资源
      • 2.10.3 资源创新
    • 2.11 佐证6.课程特色
      • 2.11.1 内容
      • 2.11.2 教学组织
      • 2.11.3 教学模式
    • 2.12 佐证7.目标实现
      • 2.12.1 考评
      • 2.12.2 能学
      • 2.12.3 辅教
  • 3 第一章 Spring 简介
    • 3.1 思政教育
    • 3.2 Sring 概述
    • 3.3 Spring 优点
    • 3.4 Spring 框架结构
    • 3.5 Spring 框架特征
    • 3.6 Spring 入门程序
    • 3.7 Spring 依赖注入
    • 3.8 本章小结
    • 3.9 习题1
  • 4 第二章 Spring中bean的配置和实例化
    • 4.1 思政教育
    • 4.2 Spring中bean的配置
    • 4.3 Bean的实例化
    • 4.4 bean的作用域
    • 4.5 Bean的生命周期
    • 4.6 Bean的装配方式
    • 4.7 应用案例:Annotation注解
    • 4.8 本章小结
    • 4.9 习题2
  • 5 第三章  Spring面向切面编程AOP
    • 5.1 Spring  AOP的基本概念
    • 5.2 通知类型介绍
    • 5.3 JDK动态代理
    • 5.4 Spring AOP
    • 5.5 应用案例:AspectJ开发
    • 5.6 本章小结
    • 5.7 习题3
  • 6 第四章  Mybatis原理
    • 6.1 基本内容
    • 6.2 JDBC的问题
    • 6.3 Hibernate的问题
    • 6.4 MyBatis优势
    • 6.5 MyBatis的工作原理
    • 6.6 MyBatis的数据库准备_MySQL
    • 6.7 应用案例:MyBatis入门程序
    • 6.8 Mybatis数据库基本操作示例
    • 6.9 习题4
  • 7 第五章  Mybatis反向工程
    • 7.1 动态SQL
    • 7.2 应用案例: Mybatis反向(逆向)工程
    • 7.3 Mybatis反向(逆向)工程代码解读
    • 7.4 习题5
  • 8 第六章  Spring、 Mybatis Mapper接口编程
    • 8.1 Mybatis反向工程生成的接口
    • 8.2 应用案例:SpringMVC、 Mybatis  Mapper接口编程
    • 8.3 习题6
  • 9 SpringMVC
    • 9.1 SpringMVC框架
    • 9.2 应用案例:SpringMVC
    • 9.3 应用案例:SpringMVC注解开发
    • 9.4 习题7
  • 10 SpringMVC数据绑定
    • 10.1 SpringMvc的数据绑定流程
    • 10.2 应用案例:SpringMVC参数绑定
    • 10.3 SpringMVC参数绑定数组和集合
    • 10.4 案例SpringMVC参数绑定数组
    • 10.5 习题8
  • 11 第九章、SpringMVC拦截器
    • 11.1 拦截器的实现
    • 11.2 拦截器的配置
    • 11.3 应用案例
    • 11.4 习题9
  • 12 第十章 文件上传
    • 12.1 文件上传原理
    • 12.2 创建工程
    • 12.3 应用案例
    • 12.4 习题10
  • 13 第十一章、课程资源管理系统
    • 13.1 系统需求
    • 13.2 开发环境
    • 13.3 数据库设计
    • 13.4 项目程序设计
  • 14 第十二章 职场沟通技能
    • 14.1 职场沟通原则与理念
  • 15 第十三章 如何与上司、同事沟通
    • 15.1 如何与上司、同事沟通
  • 16 第十四章 软件开发团队建设
    • 16.1 企业级应用开发团队组织技巧培训
应用案例:MyBatis入门程序

4.7、应用案例:MyBatis入门程序

这个案例程序目录结构如下:

其中mybatis-config.xml文件如下:

<?xml version="1.0" encoding="UTF-8"?>

<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"

    "http://mybatis.org/dtd/mybatis-3-config.dtd">

 <configuration>

 <!-- 配置默认环境为mysql -->

    <environments default="mysql">

 <!-- 配置idmysql的环境 -->

        <environment id="mysql">

 <!-- 使用JDBC的事务管理逻辑 -->

            <transactionManager type="JDBC"/>

 <!-- 配置数据库的连接池 -->

            <dataSource type="POOLED">

 <!-- 配置数据库驱动为mysql驱动 -->

                <property name="driver" value="com.mysql.jdbc.Driver"/>

 <!-- 数据库连接URL -->

                <property name="url" value="jdbc:mysql://localhost:3306/school?characterEncoding=UTF-8"/>

 <!-- 配置数据库帐号 -->

                <property name="username" value="root"/>

 <!-- 配置数据库密码 -->

                <property name="password" value="123456"/>

            </dataSource>

        </environment>

    </environments>

    <mappers>

 <!-- 导入其它xml文件    -->

    <mapper resource="entity/StudentMapper.xml"/>

    </mappers>

</configuration>

在这个文件中我们对MySQL数据库连接进行了配置,并导入了数据库中的表student的映射文件StudentMapper.xml,该文件内容如下:

<?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">

    

    <!-- 配置名称为entity的命名空间,该空间中有一些功能强大的方法 -->

    <mapper namespace="entity">

 <!-- 配置查询功能,相当于一个名称为findStudentById(int stuid)的方法 -->

    <select id="findStudentById" parameterType="Integer"

    resultType="entity.Student">

    select * from student where stuid=#{stuid}

    </select>

    </mapper>

在这个文件中我们配置了一个名称为entity的命名空间,该空间中有一个功能强大的方法,方法名为findStudentById,该方法有一个Integer类型的参数和一个entity.Student类型的返回值。

entity.Student类的定义如下:

package entity;

 

public class Student {

int stuid;

String stuname;

int stuage;

String phone;

public int getStuid() {

return stuid;

}

public void setStuid(int stuid) {

this.stuid = stuid;

}

public String getStuname() {

return stuname;

}

public void setStuname(String stuname) {

this.stuname = stuname;

}

public int getStuage() {

return stuage;

}

public void setStuage(int stuage) {

this.stuage = stuage;

}

public String getPhone() {

return phone;

}

public void setPhone(String phone) {

this.phone = phone;

}

}

entity.Student类的定义我们可以看到,该类中的成员变量完全与数据库school中的表student的字段一一对应。

需要注意的是Student.javaStudentMapper.xml两个文件是位于同一个包中的。

接下来我们编写测试程序如下:

package entity;

 

import java.io.InputStream;

 

import org.apache.ibatis.io.Resources;

import org.apache.ibatis.session.SqlSession;

import org.apache.ibatis.session.SqlSessionFactory;

import org.apache.ibatis.session.SqlSessionFactoryBuilder;

//@Test

 

public class Test {

public static void main(String[] args)throws Exception {

new Test().findStudentById();

}

public void findStudentById()throws Exception{

//读取配置文件

InputStream inp=Resources.getResourceAsStream("mybatis-config.xml");

//生成操作数据库的会话工厂

SqlSessionFactory sqlsession=new SqlSessionFactoryBuilder().build(inp);

//从会话工厂里获取一个会话

SqlSession ssion=sqlsession.openSession();

//利用会话对象的查询功能从数据库中查询数据

Student stu=ssion.selectOne("entity.findStudentById",1);

System.out.println(stu.stuname);

ssion.close();

}

 

}

程序运行结果可以看到我们能够正确的读取到数据库中的数据。