mybatis mysql schema_MyBatis学习 之 一、MyBatis简介与配置MyBatis+Spring+MySql

一、MyBatis简介与配置MyBatis+Spring+MySql

1.1MyBatis简介

MyBatis 是一个可以自定义SQL、存储过程和高级映射的持久层框架。MyBatis 摒除了大部分的JDBC代码、手工设置参数和结果集重获。MyBatis 只使用简单的XML 和注解来配置和映射基本数据类型、Map 接口和POJO 到数据库记录。相对Hibernate和Apache OJB等“一站式”ORM解决方案而言,Mybatis 是一种“半自动化”的ORM实现。

需要使用的Jar包:mybatis-3.0.2.jar(mybatis核心包)。mybatis-spring-1.0.0.jar(与Spring结合包)。

1.2MyBatis+Spring+MySql简单配置

1.2.1搭建Spring环境

1,建立maven的web项目;

2,加入Spring框架、配置文件;

3,在pom.xml中加入所需要的jar包(spring框架的、mybatis、mybatis-spring、junit等);

4,更改web.xml和spring的配置文件;

5,添加一个jsp页面和对应的Controller;

6,测试。

1.2.2建立MySql数据库

建立一个学生选课管理数据库。

表:学生表、班级表、教师表、课程表、学生选课表。

逻辑关系:每个学生有一个班级;每个班级对应一个班主任教师;每个教师只能当一个班的班主任;

使用下面的sql进行建数据库,先建立学生表,插入数据(2条以上)。

更多sql请下载项目源文件,在resource/sql中。

/* 建立数据库 */

CREATE DATABASE STUDENT_MANAGER;

USE STUDENT_MANAGER;

/***** 建立student表 *****/

CREATE TABLE STUDENT_TBL

(

STUDENT_ID VARCHAR(255) PRIMARY KEY,

STUDENT_NAME VARCHAR(10) NOT NULL,

STUDENT_SEX VARCHAR(10),

STUDENT_BIRTHDAY DATE,

CLASS_ID VARCHAR(255)

);

/*插入学生数据*/

INSERT INTO STUDENT_TBL (STUDENT_ID,

STUDENT_NAME,

STUDENT_SEX,

STUDENT_BIRTHDAY,

CLASS_ID)

VALUES (123456,

'某某某',

'女',

'1980-08-01',

121546

)

创建连接MySql使用的配置文件mysql.properties。

jdbc.driverClassName=com.mysql.jdbc.Driver

jdbc.url=jdbc:mysql://localhost:3306/student_manager?user=root&password=limingnihao&useUnicode=true&characterEncoding=UTF-8

1.2.3搭建MyBatis环境

顺序随便,现在的顺序是因为可以尽量的少的修改写好的文件。

1.2.3.1创建实体类: StudentEntity

public class StudentEntity implements Serializable {

private static final long serialVersionUID = 3096154202413606831L;

private ClassEntity classEntity;

private Date studentBirthday;

private String studentID;

private String studentName;

private String studentSex;

public ClassEntity getClassEntity() {

return classEntity;

}

public Date getStudentBirthday() {

return studentBirthday;

}

public String getStudentID() {

return studentID;

}

public String getStudentName() {

return studentName;

}

public String getStudentSex() {

return studentSex;

}

public void setClassEntity(ClassEntity classEntity) {

this.classEntity = classEntity;

}

public void setStudentBirthday(Date studentBirthday) {

this.studentBirthday = studentBirthday;

}

public void setStudentID(String studentID) {

this.studentID = studentID;

}

public void setStudentName(String studentName) {

this.studentName = studentName;

}

public void setStudentSex(String studentSex) {

this.studentSex = studentSex;

}

}

1.2.3.2创建数据访问接口

Student类对应的dao接口:StudentMapper。

public interface StudentMapper {

public StudentEntity getStudent(String studentID);

public StudentEntity getStudentAndClass(String studentID);

public List getStudentAll();

public void insertStudent(StudentEntity entity);

public void deleteStudent(StudentEntity entity);

public void updateStudent(StudentEntity entity);

}

1.2.3.3创建SQL映射语句文件

Student类的sql语句文件StudentMapper.xml

resultMap标签:表字段与属性的映射。

Select标签:查询sql。

SELECT * from STUDENT_TBL ST

WHERE ST.STUDENT_ID = #{studentID}

]]>

SELECT * from STUDENT_TBL

]]>

1.2.3.4创建MyBatis的mapper配置文件

在src/main/resource中创建MyBatis配置文件:mybatis-config.xml。

typeAliases标签:给类起一个别名。com.manager.data.model.StudentEntity类,可以使用StudentEntity代替。

Mappers标签:加载MyBatis中实体类的SQL映射语句文件。

1.2.3.5修改Spring 的配置文件

主要是添加SqlSession的制作工厂类的bean:SqlSessionFactoryBean,(在mybatis.spring包中)。需要指定配置文件位置和dataSource。

和数据访问接口对应的实现bean。通过MapperFactoryBean创建出来。需要执行接口类全称和SqlSession工厂bean的引用。

也可以不定义mapper的bean,使用注解:

将StudentMapper加入注解

@Repository

@Transactional

public interface StudentMapper {

}

对应的需要在dispatcher-servlet.xml中加入扫描:

1.2.4测试StudentMapper

使用SpringMVC测试,创建一个TestController,配置tomcat,访问index.do页面进行测试:

@Controller

public class TestController {

@Autowired

private StudentMapper studentMapper;

@RequestMapping(value = "index.do")

public void indexPage() {

StudentEntity entity = studentMapper.getStudent("10000013");

System.out.println("name:" + entity.getStudentName());

}

}

使用Junit测试:

使用Junit测试:

Java代码

@RunWith(value = SpringJUnit4ClassRunner.class)

@ContextConfiguration(value = "test-servlet.xml")

public class StudentMapperTest {

@Autowired

private ClassMapper classMapper;

@Autowired

private StudentMapper studentMapper;

@Transactional

public void getStudentTest(){

StudentEntity entity = studentMapper.getStudent("10000013");

System.out.println("" + entity.getStudentID() + entity.getStudentName());

List studentList = studentMapper.getStudentAll();

for( StudentEntity entityTemp : studentList){

System.out.println(entityTemp.getStudentName());

}

}

}

62

11

分享到:

18e900b8666ce6f233d25ec02f95ee59.png

72dd548719f0ace4d5f9bca64e1d7715.png

2010-10-11 17:46

浏览 343176

评论

28 楼

saybar

2017-01-05

哪里有源代码啊,?能否发一份?还有就是 ClassEntity 是什么类?怎么不一样啊?我邮箱:411038060@qq.com

27 楼

liangzulin

2016-12-05

classentity是啥?哪个包的类啊?

这教程并不完整啊!

26 楼

di1984HIT

2014-10-22

写的很好啊~

25 楼

mojito515

2013-05-05

引用

MapperFactoryBean的路径写错了,应该是org.mybatis.spring.mapper.MapperFactoryBean

24 楼

大猫熊

2013-02-16

你好,可以把源代码发到343816974@qq.com邮箱好吗?

23 楼

xvsfeo

2012-12-20

你好,可以把源代码发到410742933@qq.com邮箱好吗?

22 楼

hdwmp123

2012-06-13

附件哪里下载呢?

21 楼

phoenixsfans

2012-06-10

您好,我也正在学MyBatis想看看您的上面例子的源码,如果可以的话麻烦发到我邮箱 kissinglinux@gmail.com  谢谢

20 楼

hao_evolution

2012-04-10

limingnihao 写道

hao_evolution 写道

为啥加两次 @Transactional ,在service层加不就可以了?

你说的两次,第二次指的是在junit里边吧。在junit里面加@Transactional可以使在测试增删改后进行数据回滚,保证数据和测试之前的一样,不加也没问题。

@Repository

@Transactional

public interface StudentMapper {

}

个人觉得这里没必要加事务,在service层去加事务控制

19 楼

limingnihao

2012-04-09

hao_evolution 写道

为啥加两次 @Transactional ,在service层加不就可以了?

你说的两次,第二次指的是在junit里边吧。在junit里面加@Transactional可以使在测试增删改后进行数据回滚,保证数据和测试之前的一样,不加也没问题。

18 楼

hao_evolution

2012-04-09

为啥加两次 @Transactional ,在service层加不就可以了?

17 楼

xiaoqiS

2012-02-20

不错的入门教程

16 楼

幸福人生

2011-07-25

我的配置文件:

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xmlns:context="http://www.springframework.org/schema/context"

xmlns:tx="http://www.springframework.org/schema/tx"

xsi:schemaLocation="

http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans-3.0.xsd

http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd

http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd">

classpath:jdbc.local.properties

classpath:sys_config.properties

class="org.springframework.http.converter.StringHttpMessageConverter">

text/plain;charset=UTF-8

启动后报错:

Related cause: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'StudentMapper' defined in ServletContext resource [/WEB-INF/spring/appServlet/app-config.xml]: Cannot resolve reference to bean 'sqlSessionFactory' while setting bean property 'sqlSessionFactory'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in ServletContext resource [/WEB-INF/spring/appServlet/app-config.xml]: Invocation of init method failed; nested exception is java.lang.NoSuchMethodError: org.apache.ibatis.builder.xml.XMLConfigBuilder.(Ljava/io/InputStream;Ljava/lang/String;Ljava/util/Properties;)V

不知什么原因,请各位予以解答,谢谢!

15 楼

limingnihao

2011-03-11

xiaojianhx 写道

xiaojianhx 写道

事务怎么加?

哦,写错了.....

是"事务怎么处理"

使用Spring的@Transactional注解,一般写在Service层的接口方法上。

14 楼

xiaojianhx

2011-03-11

xiaojianhx 写道

事务怎么加?

哦,写错了.....

是"事务怎么处理"

13 楼

xiaojianhx

2011-03-11

事务怎么加?

12 楼

小金哥

2010-11-26

小金哥 写道

xiaojianhx 写道

我eclipse 启动tomcat的时候报错,怎么回事啊

严重: Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListener

org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [applicationContext.xml]: Initialization of bean failed; nested exception is java.lang.reflect.MalformedParameterizedTypeException

代码:

classpath:mybatis-config.xml

0956f0a970daab536ce4be0ee96b00ac.gif 遇到相同的问题,调试了一晚上没有找到原因,不知7楼是否已经解决该问题了?若解决了,请不吝赐教!

终于弄明白了,原来是spring版本的问题,MyBatis-Spring只能在spring3.0版本上使用,如果用spring3.0以下版本就会出现该问题,建议将spring升级为3.0或改用ibatis2.0!

11 楼

JavaScape

2010-11-09

resultType 与resultMap 不能同时使用。

官方使用手册里好像有这么一句,但是你的配置文件中同时配置了这两个属性:

13.

请楼主解释一下?

10 楼

小金哥

2010-10-31

xiaojianhx 写道

我eclipse 启动tomcat的时候报错,怎么回事啊

严重: Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListener

org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sqlSessionFactory' defined in class path resource [applicationContext.xml]: Initialization of bean failed; nested exception is java.lang.reflect.MalformedParameterizedTypeException

代码:

classpath:mybatis-config.xml

0956f0a970daab536ce4be0ee96b00ac.gif 遇到相同的问题,调试了一晚上没有找到原因,不知7楼是否已经解决该问题了?若解决了,请不吝赐教!

9 楼

limingnihao

2010-10-26

SQL映射语句文件

xiaojianhx 写道

不好意思,你的typeAliases,在哪里用到了....

在SQL映射语句文件中,使用的实体类(Java类型声明时),如果没有定义这个,那么我们用到实体类都需要写带包名的全称:com.manager.data.model.StudentEntity。而使用typeAliases就给这个类起了一个名字,也就是简称:StudentEntity,所以以后在使用这个实体类的时候,我们只需要写StudentEntity,而不用写带包名的全称。

« 上一页 1 2 下一页 »

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/307053.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

.NET架构小技巧(7)——做好小的项目

一屋不扫,何以扫天下。再说也没有那么多天下(大系统)可扫,更多的是一个个自己居住的小屋(手边的小项目,子模块),所以认真的开始扫自己的小屋。在visual studio中,解决方案(Solution)下可以创建多个项目(Project)&#…

使用 C# 9.0 新语法提升 if 语句美感

C# 语言一贯秉承简洁优美的宗旨,每次升级都会带来一些语法糖,让我们可以使代码变得更简洁。本文分享两个使用 C# 9.0 提升 if 语句美感的技巧示例。使用属性模式代替 IsNullOrEmpty在任何你使用 IsNullOrEmpty 的时候,可以考虑这样替换&#…

在 Azure App Service 上启用 Application Request Routing

点击上方蓝字关注“汪宇杰博客”导语我们在IIS上经常使用 Application Request Routing (ARR) 模块做反向代理。Azure App Service 使用的也是 IIS,照理来说应该也能做反代,但默认情况下它是不行的,我们来看看如何给在 App Service 上启用 AR…

【专题】多角度深入解析开放原子开源基金会

喜欢就关注我们吧!2020 年 9 月 9 日,开放原子开源基金会正式对外发声,同天,宣布百度超级链正式成为基金会首个捐赠项目。9 月 10 日,华为 OpenHarmony 操作系统开源,开放原子开源基金会获捐 OpenHarmony。…

C#刷剑指Offer | 【常考题】最小的k个数

【C#刷题】| 作者 / Edison Zhou这是EdisonTalk的第299篇学习分享我们来用之前学到的数据结构知识来刷《剑指Offer》的一些核心题目(精选了其中30道题目),希望对你有帮助!本文题目为:最小的k个数。1题目介绍题目&#…

晶振噪声及杂散_晶振如何匹配电容看了就知道

描述一、什么是晶振了解晶振之前,我们先来看一下我们最为熟悉的51单片机,我们都知道51单片机最小系统包括供电电源、复位电路以及晶振系统。这是CPU能跑起来的最基本条件。由此我们可以看到晶振在电路当中的作用,那就是晶振电路用于产生时间频…

C# 中的 ref 已经被放开,或许你已经不认识了

一&#xff1a;背景 1. 讲故事最近在翻 netcore 源码看&#xff0c;发现框架中有不少的代码都被 ref 给修饰了&#xff0c;我去&#xff0c;这还是我认识的 ref 吗&#xff1f;就拿 Span 来说&#xff0c;代码如下&#xff1a;public readonly ref struct Span<T>{public…

java中file_详细介绍Java中的File类

构造方法File f new File("文件路径")File f new File("parent","child")创建一个文件&#xff1a;//在工作空间目录下创建a.txt的文件File f new File("a.txt");f.createNewFile();在G:\路径下创建一个a.txt的文件.如果已经有的话…

.NET5全面拥抱Azure云,微软市值重回巅峰,那些年吹过的牛,都实现了!

“Microsoft Azure的重要性在于&#xff0c;它是继Windows取代DOS之后&#xff0c;微软的又一次颠覆性转型——通过在互联网架构上打造全新计算平台&#xff0c;使得Windows真正由PC和服务器延伸到“蓝天”上。” ------曾微软全球副总裁张亚勤2014年2月&#xff0c;纳德拉成为…

大象起舞——微软研发如何保持创新力和敏捷性

我有幸见证微软在近五年的变革&#xff0c;也作为局内人学习如此一个全球性的、庞大的研发团队是如何管理、自我调整和创新的。上周五应邀给一个大客户的研发中心做了一个分享&#xff0c;其中我深刻地认识到有几点创新是一种文化。作为企业需要用心营造这样一种文化&#xff0…

java 云架构_java版Spring Cloud云架构代码结构构建

本篇我们根据架构图进行代码的构建。根据微服务化设计思想&#xff0c;结合spring cloud一些优秀的项目&#xff0c;如服务发现、治理、配置化管理、路由负载、安全控制等优秀解决方案&#xff0c;使用Maven技术将框架进行模块化、服务化、原子化封装并构建&#xff0c;也为后期…

集赞有礼!进击吧! Blazor !第六期 企业内部应用建设实战

集赞有礼转发此文章至朋友圈&#xff0c;截止至直播结束前&#xff1a;集赞满20个&#xff0c;可获得Blazor贴纸&#xff1b;集赞满50个&#xff0c;可获得微软帆布包&#xff1b;集赞满88个&#xff0c;可获得笔记本&#xff1b;集赞最多的一位小伙伴将获得充电宝哦&#xff0…

基于阿里云日志服务快速打造简版业务监控看板

前言 最近老黄一直在弄双11相关的东西&#xff0c;所以博客和github都没怎么更新&#xff0c;这期间在公司也弄了不少东西。下面就简单分享一下最近做的业务监控相关的内容吧。先来说一下背景。某业务在双11第一波大促的时候因为没有提供实时的业务看板&#xff0c;总结会的时候…

一个.NET Core下的开源插件框架Pluginfactory

插件模式历史悠久&#xff0c;各种中大型软件基本上都会实现插件机制&#xff0c;以此支持功能扩展&#xff0c;从开发部署层面&#xff0c;插件机制也可实现功能解耦&#xff0c;对于并行开发、项目部署、功能定制等都有比较大的优势。在.NET Core下&#xff0c;一般我们基于.…

谈谈.NET Core IServiceProvider

【导读】最近重构部分代码&#xff0c;因历史原因在静态类中需使用注入实例&#xff0c;构造函数注入则不再可取&#xff0c;此时只能构造全局IServiceProvider&#xff0c;所以本文稍微分析下IServiceProvider要构造全局使用IServiceProvider&#xff0c;我们都知道不能在Conf…

使用 Xunit.DependencyInjection 改造测试项目

使用 Xunit.DependencyInjection 改造测试项目Intro这篇文章拖了很长时间没写&#xff0c;之前也有介绍过 Xunit.DependencyInjection 这个项目&#xff0c;这个项目是由大师写的一个 Xunit 基于微软 GenericHost 和 依赖注入实现的一个扩展库&#xff0c;可以让你更方便更容易…

discuz mysql data_Discuz!显示 Database Error的原因和解决方法

今天打开Discuz搭建的论坛显示&#xff1a;原因一&#xff1a;数据库表太大比如mysql数据库的表内容太大&#xff0c;超过10G就有可能会影响discuz论坛的运行。Discuz! Database Error是什么原因&#xff0c;怎么修复这种情况可以通过对数据库分表的方法来解决。原因二&#xf…

项目开发中经常有一些被嫌弃的小数据,现在全丢给 FastDFS

在我们开发项目的时候&#xff0c;经常会遇到大块数据的问题&#xff08;2M-100M&#xff09;&#xff0c;比如说保存报表中1w个人的ID号&#xff0c;说实话&#xff0c;这些数据存储在服务器哪里都被嫌弃&#xff0c;放在redis&#xff0c;mongodb中吧&#xff0c;一下子你就会…

java 反射 int_Java 反射由浅入深 | 进阶必备

原标题&#xff1a;Java 反射由浅入深 | 进阶必备一、Java 反射机制参考了许多博文&#xff0c;总结了以下个人观点&#xff0c;若有不妥还望指正&#xff1a;Java 反射机制在程序运行时&#xff0c;对于任意一个类&#xff0c;都能够知道这个类的所有属性和方法&#xff1b;对…

寻找性能更优秀的不可变小字典

Dictionary 是一个很常用的键值对管理数据结构。但是在性能要求严苛的情况下&#xff0c;字典的查找速度并不高。所以&#xff0c;我们需要更快的方案。需求说明 这里&#xff0c;我们需要一个 PropertyInfo 和委托对应的映射关系&#xff0c;这样我们就可以存储《寻找性能更优…