笔记要点&出错分析与总结

  POJO(Plain Ordinary Java Object)简单的Java对象,实际就是普通JavaBeans,
工程组织  

(AirportService为机场服务站接口,定义了 List<Airport> show();

package com03.service;

import com03.bean.Airport;
import org.apache.ibatis.annotations.Select; import java.util.List; public interface AirportService { List<Airport> show();
}

  AirportserviceImpl 是该接口的提供具体的实现类,重写接口的方法,并有get/set 方法

    public List<Airport> show() {
      return airportMapper.selectAll();
    }

package com03.service;

import com03.bean.Airport;
import com03.mapper.AirportMapper; import java.util.List; public class AirportServiceImpl implements AirportService{
private AirportMapper airportMapper;
@Override
public List<Airport> show() {
return airportMapper.selectAll();
} public AirportMapper getAirportMapper() {
return airportMapper;
} public void setAirportMapper(AirportMapper airportMapper) {
this.airportMapper = airportMapper;
}
}

  AirportMapper接口  实现从数据库查询信息返回List<Airport> )

package com03.mapper;
import com03.bean.Airport;
import org.apache.ibatis.annotations.Select;
import java.util.List;
public interface AirportMapper {
@Select("select * from airport")
public List<Airport> selectAll();
}

具体结构图,并1.导入mybatis所有jar 包 ,spring基本包spring-jdbc,spring-tx,spring-aop,spring-web,spring整合mybatis 的包等.

数据库组织

    id  airplane_no    time   price  takeoff_id  land_id
------ ----------- ------ ------ ---------- ---------
1 波音747 123 100 1 3
2 波音858 56 300 3 2

0.定义Bean类  Airport

package com03.bean;

public class Airport {
private int id;
private String portName;
private String cityName;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getPortName() {
return portName;
}
public void setPortName(String portName) {
this.portName = portName;
}
public String getCityName() {
return cityName;
}
public void setCityName(String cityName) {
this.cityName = cityName;
}
@Override
public String toString() {
return "Airport [id=" + id + ", portName=" + portName + ", cityName=" + cityName + "]";
}
}

1.定义接口 (见上面)
2.定义Spring的XML映射文件  applicationContext.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/beans/spring-beans.xsd">
<!--配置Mybatis的基本登陆信息,连接信息;除了事务方面的-->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://localhost:3306/ssm"></property>
<property name="username" value="root"></property>
<property name="password" value="123456"></property>
</bean>
<bean id="factory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
</bean>
<!--扫描相当于mybatis.xml中的mapper的package标签; 扫描指定文件夹下的全部配置文件/接口,会自动为接口创建对象-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!--要扫描那个包-->
<property name="basePackage" value="com03.mapper"></property>
<!--和factory 产生关系-->
<property name="sqlSessionFactory" ref="factory"></property>
</bean>
<!--ref="airportMapper" ,上一步扫描完全局配置和接口文件后,会自动创建该bean-->
<!--由Spring -->
<bean id="airportService" class="com03.service.AirportServiceImpl">
<property name="airportMapper" ref="airportMapper"></property>
</bean>
</beans>

3.编写测试代码 test01   (配置文件不在默认的SRC下, 在 com03/conf/applicationContext.xml)

package com03.test;

import com03.bean.Airport;
import com03.service.AirportServiceImpl;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext; import java.util.List; public class test01 {
public static void main(String[] args) {
//创建Spring 容器 ,默认去根目录开始寻找
ApplicationContext ac=new ClassPathXmlApplicationContext("com03/conf/applicationContext.xml");
String[] names = ac.getBeanDefinitionNames();
for (String name:names
) {
System.out.println("★Spring自动创建了:"+" "+name);
}
AirportServiceImpl bean = ac.getBean("airportService", AirportServiceImpl.class);
List<Airport> list = bean.show();
System.out.println("★"+list);
}
}

测试结果

★Spring自动创建了:  dataSource
★Spring自动创建了: factory
★Spring自动创建了: org.mybatis.spring.mapper.MapperScannerConfigurer#0
★Spring自动创建了: airportService
★Spring自动创建了: airportMapper
★Spring自动创建了: org.springframework.context.annotation.internalConfigurationAnnotationProcessor
★Spring自动创建了: org.springframework.context.annotation.internalAutowiredAnnotationProcessor
★Spring自动创建了: org.springframework.context.annotation.internalRequiredAnnotationProcessor
★Spring自动创建了: org.springframework.context.annotation.internalCommonAnnotationProcessor
★Spring自动创建了: org.springframework.context.annotation.ConfigurationClassPostProcessor.importAwareProcessor
★Spring自动创建了: org.springframework.context.annotation.ConfigurationClassPostProcessor.enhancedConfigurationProcessor
DEBUG 12-08 10:44:15,527 JDBC Connection [com.mysql.jdbc.JDBC4Connection@399f45b1] will not be managed by Spring  (SpringManagedTransaction.java:87)
DEBUG 12-08 10:44:15,532 ==> Preparing: select * from airport (BaseJdbcLogger.java:139)
DEBUG 12-08 10:44:15,556 ==> Parameters: (BaseJdbcLogger.java:139)
DEBUG 12-08 10:44:15,572 <== Total: 3 (BaseJdbcLogger.java:139)
DEBUG 12-08 10:44:15,572 Closing non transactional SqlSession [org.apache.ibatis.session.defaults.DefaultSqlSession@3eb7fc54] (SqlSessionUtils.java:193)
DEBUG 12-08 10:44:15,572 Returning JDBC Connection to DataSource (DataSourceUtils.java:327)
★[Airport [id=1, portName=首都机场, cityName=北京], Airport [id=2, portName=南阳机场, cityName=南阳], Airport [id=3, portName=虹桥机场, cityName=上海]]

Spring4- 04-Spring简易整合Mybatis -导入jar包/ 正常编写pojo/ 编写spring 配置文件的更多相关文章

  1. spring+mybits 整合所需jar包的下载路径(亲测有效)

    1.spring jar包:http://repo.springsource.org/libs-release-local/org/springframework/spring/5.0.0.RELEA ...

  2. Spring Boot 整合mybatis时遇到的mapper接口不能注入的问题

    现实情况是这样的,因为在练习spring boot整合mybatis,所以自己新建了个项目做测试,可是在idea里面mapper接口注入报错,后来百度查询了下,把idea的注入等级设置为了warnin ...

  3. spring boot 整合 mybatis 以及原理

    同上一篇文章一样,spring boot 整合 mybatis过程中没有看见SqlSessionFactory,sqlsession(sqlsessionTemplate),就连在spring框架整合 ...

  4. Spring环境搭建之:导入jar包、配置文件名称及放置位置

    Spring环境搭建之:导入jar包.配置文件名称及放置位置 现在项目开发中spring框架应用的还是比较多的,自己用的还不太熟练,每次用的时候总配置半天,总有些配置弄错,就找个时间总结以下,方便以后 ...

  5. Spring Boot整合Mybatis并完成CRUD操作

    MyBatis 是一款优秀的持久层框架,被各大互联网公司使用,本文使用Spring Boot整合Mybatis,并完成CRUD操作. 为什么要使用Mybatis?我们需要掌握Mybatis吗? 说的官 ...

  6. Spring Boot整合Mybatis报错InstantiationException: tk.mybatis.mapper.provider.base.BaseSelectProvider

    Spring Boot整合Mybatis时一直报错 后来发现原来主配置类上的MapperScan导错了包 由于我使用了通用Mapper,所以应该导入通用mapper这个包

  7. ssm框架整合---maven工具来导入jar包

    ssm整合 一.导包(pom.xml文件) <?xml version="1.0" encoding="UTF-8"?> <project x ...

  8. Spring Boot系列(三):Spring Boot整合Mybatis源码解析

    一.Mybatis回顾 1.MyBatis介绍 Mybatis是一个半ORM框架,它使用简单的 XML 或注解用于配置和原始映射,将接口和Java的POJOs(普通的Java 对象)映射成数据库中的记 ...

  9. 太妙了!Spring boot 整合 Mybatis Druid,还能配置监控?

    Spring boot 整合 Mybatis Druid并配置监控 添加依赖 <!--druid--> <dependency> <groupId>com.alib ...

随机推荐

  1. E: Unable to correct problems, you have held broken packages-之apt-get 下载报依赖问题

    今天在新来了一台ubutnu 18.04 在安装zabbix客户端是报依赖问题 root@VM_0_10:~# apt-get install zabbix-agent Reading package ...

  2. Activiti6.0流程编辑器汉化教程(en.json文件汉化)

    { "GENERAL": { "MAIN-TITLE": "Activiti", "ERROR": { "GE ...

  3. IDEA下同时使用Git和svn

    使用Git时将文件改成Git,Svn时改成svn 修改项目下.idea目录的vcs.xml配置文件. <?xml version="1.0" encoding="U ...

  4. mysql杂项

    取数据库某个表中的所有的字段 select COLUMN_NAME from information_schema.COLUMNS where table_name = 'your_table_nam ...

  5. 学习数据结构Day4

    链表 之前看过了动态数组,栈和队列,虽然我们把第一个叫做动态数组,但是,他们的底层实质上还是静态数组.靠 resize来实现动态数组.而链表是真正的数据结构 链表需要一个节点. 数据存储在链表中 相当 ...

  6. mvn命令着中package、install、deploy的区别

    参考:https://blog.csdn.net/zhaojianting/article/details/80324533 常用操作区别 mvn clean package 依次执行了clean.r ...

  7. 【转帖】处理器史话 | 这张漫画告诉你,为什么双核CPU能打败四核CPU?

    处理器史话 | 这张漫画告诉你,为什么双核CPU能打败四核CPU? https://www.eefocus.com/mcu-dsp/371324 2016-10-28 10:28 作者:付丽华预计 9 ...

  8. 用海豚框架(DolphinPHP)实现单/多图片上传时,如何获得图片路径

    用框架实现图片上传很简单,就不多说了,然后这个框架的实现机制是这样的,我们选择图片,点击上传,他会将图片保存在uploads下,以当天时间和随机字母作为图片名,然后在返回个数字,这个数字是这个图片的i ...

  9. 前端 html篇

    web开发本质: html是一个标准,规定了大家怎么写网页 1.浏览器输入网址回车发生了什么事 1. 浏览器 给服务端 发送了一个消息2. 服务端拿到消息3. 服务端返回消息4. 浏览器展示页面 se ...

  10. 函数的练习1——python编程从入门到实践

    8-1 消息: 编写一个名为display_message()的函数,它打印一个句子指出你在本章学的是什么.调用这个函数,确认显示的消息正确无误. def display_message(): pri ...