mybatis 基础项目搭建

本文介绍了MyBatis,一个优秀的持久层框架,它简化了JDBC代码和手动参数设置。通过XML或注解配置,MyBatis能将Java对象映射到数据库记录。文章详细阐述了如何开始使用MyBatis,包括添加依赖、创建测试表、编写实体类、测试接口、SQL映射文件及核心配置文件,最后展示了如何测试并打印所有数据库查询结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

什么是 MyBatis?
MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集。MyBatis 可以使用简单的 XML 或注解来配置和映射原生类型、接口和 Java 的 POJO(Plain Old Java Objects,普通老式 Java 对象)为数据库中的记录。

Getting started
要使用 MyBatis, 只需将 mybatis-x.x.x.jar 文件置于 classpath 中即可。 如果使用 Maven 来构建项目,则需将下面的 dependency 代码置于 pom.xml 文件中:

<dependency>
   <groupId>org.mybatis</groupId>
   <artifactId>mybatis</artifactId>
   <version>3.5.0</version>
</dependency>

由于要我操作的是mysql数据库,所以再引入mysql驱动包

mysql mysql-connector-java 8.0.15 首先工程目录结构如下: ![在这里插入图片描述](https://img-blog.csdnimg.cn/20190723132346611.png)

1.创建一张测试表:t_user
在这里插入图片描述

2.然后根据表字段,写出实体类

//orm映射:要求实体类属性和数据库表字段要一一对应
public class User {

	private String userId;
	private String userName;
	private int age;
	private String phone;
	private String address;

	//Getters和Setters方法省略

	@Override
	public String toString() {
		return "{userId=" + userId + ", userName=" + userName + ", age=" + age + ", phone=" + phone + ", address="
				+ address + "}";
	}
}

3.写一个测试接口

public interface UserMapper {

	List<User> selectAll();
}

4.编写sql映射文件:UserMapper.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">
  
<!-- namespace:接口全类名 -->
<mapper namespace="com.bdqn.zmj.api.UserMapper">

	<!-- 实体类属性名和数据库字段名不一致的字段需要自己定义映射关系 -->
	<resultMap type="user" id="userMap">
		<id property="userId" column="uid"/>
		<result property="userName" column="uname"/>
	</resultMap>

	<select id="selectAll" resultMap="userMap">
		select * from t_user
	</select>
	
</mapper>

5.核心配置文件: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>

	<properties resource="db.properties"></properties>

	<!-- 别名配置 -->
	<typeAliases>
		<package name="com.bdqn.zmj.entity"/>
	</typeAliases>

	<environments default="development">
		<environment id="development">
			<transactionManager type="JDBC" />
			<dataSource type="POOLED">
				<property name="driver" value="${driver}" />
				<property name="url" value="${url}" />
				<property name="username" value="${username}" />
				<property name="password" value="${password}" />
			</dataSource>
		</environment>
	</environments>
	<mappers>
		<mapper resource="com/bdqn/zmj/mapper/UserMapper.xml" />
	</mappers>
</configuration>

6.测试

public class Test {

	public static void main(String[] args) {

		try {
			String resource = "mybatis-config.xml";
			InputStream is = Resources.getResourceAsStream(resource);
			SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is);

			//获取sqlsession
			SqlSession session = factory.openSession();
			UserMapper mapper = session.getMapper(UserMapper.class);

			List<User> list = mapper.selectAll();
			for (User user : list) {
				System.out.println(user);
			}

			session.close();//关闭sqlsession

		} catch (IOException e) {
			e.printStackTrace();
		}
	}
}

将数据库查询到的所有数据打印如下:

在这里插入图片描述

资源下载链接为: https://pan.quark.cn/s/d9ef5828b597 在本文中,我们将探讨如何通过 Vue.js 实现一个带有动画效果的“回到顶部”功能。Vue.js 是一款用于构建用户界面的流行 JavaScript 框架,其组件化和响应式设计让实现这种交互功能变得十分便捷。 首先,我们来分析 HTML 代码。在这个示例中,存在一个 ID 为 back-to-top 的 div 元素,其中包含两个 span 标签,分别显示“回到”和“顶部”文字。该 div 元素绑定了 Vue.js 的 @click 事件处理器 backToTop,用于处理点击事件,同时还绑定了 v-show 指令来控制按钮的显示与隐藏。v-cloak 指令的作用是在 Vue 实例渲染完成之前隐藏该元素,避免出现闪烁现象。 CSS 部分(backTop.css)主要负责样式设计。它首先清除了一些默认的边距和填充,对 html 和 body 进行了全屏布局,并设置了相对定位。.back-to-top 类则定义了“回到顶部”按钮的样式,包括其位置、圆角、阴影、填充以及悬停时背景颜色的变化。此外,与 v-cloak 相关的 CSS 确保在 Vue 实例加载过程中隐藏该元素。每个 .page 类代表一个页面,每个页面的高度设置为 400px,用于模拟多页面的滚动效果。 接下来是 JavaScript 部分(backTop.js)。在这里,我们创建了一个 Vue 实例。实例的 el 属性指定 Vue 将挂载到的 DOM 元素(#back-to-top)。data 对象中包含三个属性:backTopShow 用于控制按钮的显示状态;backTopAllow 用于防止用户快速连续点击;backSeconds 定义了回到顶部所需的时间;showPx 则规定了滚动多少像素后显示“回到顶部”按钮。 在 V
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值