Mybatis入门程序-根据id查询数据

JAVAEE实践系列

1. Spring入门程序
2. 依赖注入实现方法
3. Bean基于注解方式的装配
4. AspectJ开发及其两种实现方法
5. Mybatis入门程序-根据id查询数据


概括

本文包括以下内容:

  1. Mybatis入门程序:创建mysql数据库,导入需要的jar包,编写映射文件以及核心配置文件等
  2. 扩展内容包括安装mysql数据库,安装MySQL可视化工具之Navicatfor MySQL,mysql驱动jar包的下载,关于如何创建log4j.properties文件,Juint测试的使用

一、步骤截图

1. 在mysql数据库中创建mybatis06的数据库,创建t_costomer表,插入三条数据

安装mysql数据库
安装MySQL可视化工具之Navicat for MySQL

在这里插入图片描述

2.创建web项目,导入jar包。将mybatis的核心jar包,lib目录下的依赖包,以及mysql数据库的驱动jar包添加到web项目的lib目录下,并发布到类路径中。

mysql驱动jar包的下载

在这里插入图片描述

3.在src目录下创建log4j.properties。mybatis默认使用log4j输出日志信息,所以配置日志文件,用于查看控制台输出的sql语句

不要求掌握直接复制即可

在这里插入图片描述

关于如何创建log4j.properties文件

new–>others–>输入file并选择–>输入文件名时加上你想要的后缀即可
在这里插入图片描述
在这里插入图片描述

4. src目录下创建po包,创建pojo类Customer,声明属性以及getter,setter方法。

客户持久化类POJO类,声明属性,及其对应的getter和setter方法

在这里插入图片描述

5. src目录下创建mapper包,创建映射文件CustomerMapper.xml

映射文件,里面有sql语句
select是执行查询操作的配置 ,参数如下:

  1. id指定了其唯一标识符
  2. parameterType指定了传入参数的类型,这里表示传递给执行sql的是一个integer类型的参数
  3. resultType指定了返回结果的类型,这里表示返回的数据是Customer类型(包+Customer类名)

sql语句中:

  1. 定义查询的sql语句,#{}用于表示一个占位符,相当于"?"
  2. 而’#{id}表示该占位符等待接收参数的名称是id’

在这里插入图片描述

6. src目录下创建MyBatis的核心配置文件mybatis-config.xml

配置了mybatis的运行环境等信息,其主要内容是获取数据库连接

在这里插入图片描述

7. src目录下创建test包,创建创建测试类MybatisTest,在类中编写测试方法findCustomerByIdTest().

Juint测试的使用

在这里插入图片描述

二、输出结果

在这里插入图片描述

三、整体代码

目录结构

在这里插入图片描述

1. log4j.properties

#Global logging configuration
log4j.rootLogger=ERROR, stdout
#MyBatis logging configuration
log4j.logger.com.itheima=DEBUG
#Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

2. POJO类:po包下Customer.java

package com.itheima.po;

/*
 * 客户持久化类POJO类,声明属性,及其对应的getter和setter方法
 * */

public class Customer {
	private Integer id; //主键id
	private String username; //客户名称
	private String jobs; //职业
	private String phone; //电话
	public Integer getId() {
		return id;
	}
	public void setId(Integer id) {
		this.id = id;
	}
	public String getUsername() {
		return username;
	}
	public void setUsername(String username) {
		this.username = username;
	}
	public String getJobs() {
		return jobs;
	}
	public void setJobs(String jobs) {
		this.jobs = jobs;
	}
	public String getPhone() {
		return phone;
	}
	public void setPhone(String phone) {
		this.phone = phone;
	}
	//右键source,里面有一个generate toString()
	@Override
	public String toString() {
		return "Customer [id=" + id + ", username=" + username + ", jobs=" + jobs + ", phone=" + phone + "]";
	}	
}

3. 映射文件:Mapper包下CustomerMapper.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">
<!-- <mapper>是配置文件的根元素,namespace指定了该mapper的唯一命名空间,通常是包名+sql映射文件名 -->
<mapper namespace="com.itheima.mapper.CustomerMapper">
<!-- select是执行查询操作的配置 -->
<!-- id指定了其唯一标识符 -->
<!-- parameterType指定了传入参数的类型,这里表示传递给执行sql的是一个integer类型的参数 -->
<!-- resultType指定了返回结果的类型,这里表示返回的数据是Customer类型(包+Customer类名) -->
	<select id="findCustomerById" parameterType="Integer" resultType="com.itheima.po.Customer">
 		<!-- 定义查询的sql语句,#{}用于表示一个占位符,相当于"?" -->
 		<!-- 而'#{id}表示该占位符等待接收参数的名称是id' -->
 		select * from t_costomer where id = #{id}
	</select>
</mapper>

4. 核心配置文件: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">
<!-- mybatis-config.xml是核心配置文件(全局配置文件) -->
<!-- 配置了mybatis的运行环境等信息,其主要内容是获取数据库连接 -->
<configuration>
	<!-- 1. 配置环境,默认环境id是mysql -->
	<environments default="mysql">
	<!-- 配置id为mysql的数据库环境 -->
		<environment id="mysql">
			<!-- 使用JDBC事务管理 -->
			<transactionManager type="JDBC"/>
			<!-- 数据库连接池 -->
			<dataSource type="POOLED">
			<property name="driver" value="com.mysql.jdbc.Driver"/>
			<!-- 后面是数据库名字 -->
			<property name="url" value="jdbc:mysql://localhost:3306/mybatis06"/>
			<property name="username" value="root"/>
			<property name="password" value="123456"/>
			</dataSource>
		</environment>
	</environments>
	<!-- 2. 配置Mapper的位置(映射文件的位置) -->
	<mappers>
		<mapper resource="com/itheima/mapper/CustomerMapper.xml"/>
	</mappers>
</configuration>

5. 测试类:Test包下MyBatisTest.java

package com.ithiema.test;

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;
import org.junit.Test;

import com.itheima.po.Customer;

public class MyBatisTest {
	/*
	 * 根据客户编号查询客户信息
	 * */
	//Junit测试的方法前面必须写@Test
	@Test
	public void findCustomerByIdTest() throws Exception{
		//1. 读取核心配置文件
		String resource = "mybatis-config.xml";
		//通过输入流读取配置文件
		InputStream inputStream = Resources.getResourceAsStream(resource);
		//2. 根据配置文件构建sqlSessionFactory;
		SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
		//3. 通过sqlSessionFactory创建sqlSession
		SqlSession sqlSession = sqlSessionFactory.openSession();
		//4. sqlSession执行映射文件中定义的sql,并返回映射结果
		//selectOne第一个参数是select的id(包+映射文件名.select的id名)
		//selectOne第二个参数是查询所需要的参数,这里查询id为1的客户
		Customer customer = sqlSession.selectOne("com.itheima.mapper"+".CustomerMapper.findCustomerById",1);
		//打印输出结果
		System.out.println(customer.toString());
		//5. 关闭sqlSession 
		sqlSession.close();
	}
}


今日感受

自己实践写代码+写博客真的需要很长时间,还有好几个我想写的还没写哈哈,等晚上再复习测试吧。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值