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)&#…

mysql java驱动 ibm_JDBC驱动汇总

JDBC驱动汇总在这边简单整理一下比较代表性的driver跟使用方式有鉴于许多版友对于寻找JDBC driver或者如何使用driver常常发问,在这边我简单整理一下比较代表性的driver跟使用方式.Microsoft SQL Server series (6.5, 7.x and 2000) and Sybase 10JDBC Name: jTDSURL: http://j…

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

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

python连接mongodb数据库_python连接mongodb操作数据示例(mongodb数据库配置类)

一、相关代码数据库配置类 MongoDBConn.py代码如下:#encodingutf-8Mongo Conn连接类import pymongoclass DBConn:conn Noneservers "mongodb://localhost:27017"def connect(self):self.conn pymongo.Connection(self.servers)def close(self):return self.conn.d…

在 Azure App Service 上启用 Application Request Routing

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

mysql isolation level_MySQL数据库事务隔离级别(Transaction Isolation Level)

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼1.全局修改,修改mysql.ini配置文件,在最后加上1 #可选参数有:READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, SERIALIZABLE.2 [mysqld]3 transaction-isolation REPEATABLE-READ这里全局默…

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

喜欢就关注我们吧!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;纳德拉成为…

activex java 控件_java 如何调用ActiveX控件??

仓库发料系统.loginInputText{border: 1px solid #000000;padding-left: 2px;padding-right: 2px;padding-top: 1px;padding-bottom: 1px;font-weight:bold;background-color:#ffffff;color: #343E5F;width:144px;}.loginInputButton{border: 1px solid #000000;padding-left: …

Blazor 准备好为企业服务了吗?

如果您正在编写 .NET Web 应用程序&#xff0c;您很可能已经意识最近一年在.NET Web开发领域的热点都是 Blazor 的。如果你还没有了解Blazor&#xff0c;它允许您使用 C# 来编写 Web 应用程序&#xff0c;传统上您必须使用 JavaScript。过去两年&#xff0c;我已经看到它从一个…

core java面试题_CoreJava基础面试题

1、局部变量的概念及特点局部变量是声明在方法内的变量特点1.必须先赋值才能使用2.作用范围从声明开始到它所在的代码块结束3.在重合的作用范围之内不允许局部变量名字相同2、方法重载和方法覆盖的区别&#xff1f;方法的重载要求方法名必须相同&#xff0c;形参列表必须不同&a…

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

我有幸见证微软在近五年的变革&#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…

java spring 拦截器_Spring MVC拦截器(Interceptor)的配置及使用

在开发一个网站时可能有这样的需求&#xff1a;某些页面只希望几个特定的用户浏览。对于这样的访问权限控制&#xff0c;应该如何实现呢&#xff1f;拦截器就可以实现上述需求。在 Struts 2 框架中&#xff0c;拦截器是其重要的组成部分&#xff0c;Spring MVC 框架也提供了拦截…

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

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