springboot整合mybatis实现增删改查

springboot整合mybatis实现增删改查立志存高远,笃行践初心三更灯火五更鸡,正是男儿读书时。黑发不知勤学早,白首方悔读书迟。立志,标定人生方向;奋斗,创造人生价值,二者相辅相成,互相促进。大部分程序员的「目标」都是成为一名优秀的工程师,一名可以统览全局的「架构师」。千里之行始于足下对于大部分普通人而言,成为一名优秀的架构师还是有一定难度的,「千里之行始于足下,一步一个脚印,慢慢来」。????粉丝专属福利:包邮送书3本,如下书单四选一。????获取方式:1、参与文末投票,点赞,收藏即有机会获得精

大家好,又见面了,我是你们的朋友全栈君。

立志存高远,笃行践初心 

三更灯火五更鸡,正是男儿读书时。 黑发不知勤学早,白首方悔读书迟。

立志,标定人生方向;奋斗,创造人生价值,二者相辅相成,互相促进。

大部分程序员的「 目标 」都是成为一名优秀的工程师,一名可以统览全局的「 架构师 」

千里之行始于足下 

对于大部分普通人而言,成为一名优秀的架构师还是有一定难度的,「 千里之行始于足下,一步一个脚印,慢慢来 」

springboot整合mybatis实现增删改查

很多小伙伴私下问我,没有实际的开发经验,自学成才、或者是培训班出来的,简历上的项目经验怎么写?我觉得可以简简单单的写一个SSM整合项目。

目录

立志存高远,笃行践初心 

千里之行始于足下 

亿级流量Java高并发与网络编程实战 

一、Spring思维导图

二、Spring

1、基本概念

2、Spring的流程图

3、spring的优点

4、spring的缺点

三、SpringMVC

1、基本概念

2、SpringMVC的优点

3、SpringMVC的缺点

四、mybatis

1、基本概念

2、mybatis的优点

五、前置知识总结

六、Java程序员简历上的第一个项目

Spring、SpringMVC、MyBatis整合

1、大体框架

 2、引入jar包

 3、配置

4、编写代码

5、运行


一、Spring思维导图

springboot整合mybatis实现增删改查

二、Spring

1、基本概念

spring是一个开源开发框架,是一个轻量级控制反转(IoC)和面向切面(AOP)的容器框架。

spring主要用来开发java应用,构建J2EE平台的web应用。其核心就是提供一种新的机制管理业务对象及其依赖关系。

2、Spring的流程图

springboot整合mybatis实现增删改查

解析:上面是在Struts结构图的基础上加入了spring流程图,在web.xml配置文件中加入了spring的监听器,在struts.xml配置文件中添加   

<constant name="struts.objectFactory" value="spring" />

是告知Struts2运行时使用spring来管理对象,spring在其中主要做的就是注入实例,所有需要类的实例都由spring管理。

3、spring的优点

容器:spring是一个容器,包含并管理对象的生命周期和配置。可以配置每个bean如何被创建,基于一个可配置原型prototype,你的bean可以创建一个单独的实例或者每次需要时都生成一个新的实例。
支持AOP:spring提供对AOP的支持,它允许将一些通用任务,如安全、事物、日志等进行集中式处理,从而提高了程序的复用性。
轻量级框架:spring是轻量级框架,其基本的版本大约2M。
控制反转:spring通过控制反转实现松耦合。对象们给他们依赖,而不是对象本身,方便解耦,简化开发。
方便程序测试:spring提供了Junit4的支持,可以通过注解方便的测试spring程序。
降低java EE API的使用难度:spring对java EE开发中非常难用的一些API(比如JDBC),都提供了封装,使这些API应用难度大大降低。
方便集成各种优秀框架:spring内部提供了对各种优秀框架(如Struts、mybatis)的直接支持。
支持声明式事务处理:只需要通过配置就可以完成对事务的管理,而无须手动编程。

4、spring的缺点

  • 依赖反射,反射影响进程。
  • 太过于依赖设计模式。
  • 控制器过于灵活。
  • 不支持分布式应用。

三、SpringMVC

1、基本概念

属于spring框架的一部分,用来简化MVC架构的web应用程序开发。

2、SpringMVC的优点

  1. 拥有强大的灵活性,非侵入性和可配置性
  2. 提供了一个前端控制器dispatcherServlet,开发者无需额外开发控制器对象
  3. 分工明确,包括控制器、验证器、命令对象、模型对象、处理程序映射视图解析器,每一个功能实现由一个专门的对象负责完成
  4. 可以自动绑定用户输入,并正确的转换数据类型
  5. 可重用的业务代码:可以使用现有的业务对象作为命令或表单对象,而不需要去扩展某个特定框架的基类。

3、SpringMVC的缺点

  1. servlet API耦合难以脱离容器独立运行
  2. 太过于细分,开发效率低

四、mybatis

1、基本概念

mybatis是一个简化和实现了java数据持久层的开源框架,它抽象了大量的JDBC冗余代码,并提供了一个简单易用的API和数据库交互。

2、mybatis的优点

  1. 与JDBC相比,减少了50%以上的代码量。
  2. mybatis是最简单的持久化框架,小巧并且简单易学。
  3. mybatis灵活,不会对应用程序或者数据库的限售设计强加任何影响,SQL写在XML里,从程序代码中彻底分离,降低耦合度,便于统一管理和优化,可重用。
  4. 提供XML标签,支持编写动态SQL语句(XML中使用if,else)。
  5. 提供映射标签,支持对象与数据库的ORM字段关系映射(在XML中配置映射关系,也可以使用注解)

3、mybatis的缺点

  1. SQL语句的编写工作量较大,对开发人员的SQL语句编写有一定的水平要求。
  2. SQL语句过于依赖数据库,不能随意更换数据库。
  3. 拼接复杂SQL语句时不灵活。

五、前置知识总结

Java框架总结

Spring AOP基础知识总结

Spring常用注解(绝对经典)

SpringMVC中put和post如何选择

@RequestParam、@ModelAttribute、@RequestBody的区别

mybatis常用注解(绝对经典)

【MyBatis 基础知识总结 1】SQL注入

【MyBatis 基础知识总结 2】MyBatis-Plus

【MyBatis 基础知识总结 3】MyBatis一级缓存和二级缓存

【MyBatis 基础知识总结 4】动态sql

【MyBatis 基础知识总结 5】SqlSessionFactory和SqlSession

【MyBatis 基础知识总结 6】Statement、PreparedStatement和CallableStatement

六、Java程序员简历上的第一个项目

Spring、SpringMVC、MyBatis整合

1、大体框架

springboot整合mybatis实现增删改查

 2、引入jar包

springboot整合mybatis实现增删改查

 3、配置

与spring整合时,mybatis的配置文件conf.xml(数据源+mapper.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"
	xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
 
	<bean id="config" class="org.springframework.beans.factory.config.PreferencesPlaceholderConfigurer">
		<property name="locations">
			<array>
				<value>classpath:db.properties</value>
			</array>
		</property>
	</bean>
 
	<!-- 配置数据库信息(替代mybatis的配置文件confx.ml)   -->
	<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
		<property name="driverClassName" value="${driver}"></property>
		<property name="url" value="${url}"></property>
		<property name="username" value="${username}"></property>
		<property name="password" value="${password}"></property>
	</bean> 
	
	<!-- 在springIOC中创建mybatis的核心类SqlSessionFactoryBean  -->
	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="dataSource" ref="dataSource"></property>
		<property name="mapperLocations" value="classpath:com/guor/mapper/*.xml"></property>
	</bean> 
 
	<bean id="studentService" class="com.guor.service.impl.StudentServiceImpl">
		<property name="studentMapper" ref="studentMapper"></property>
	</bean>
	
	<!-- 批量产生mapper对象在IOC中的id值默认就是接口名-->
	<bean id="mappers" class="org.mybatis.spring.mapper.MapperScannerConfigurer">
		<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>  
		<!-- 指定批量产生哪个包的mapper对象 -->
		<property name="basePackage" value="com.guor.mapper"></property>  
	</bean>
</beans>

数据库配置 

driver=oracle.jdbc.OracleDriver
url=jdbc:oracle:thin:@127.0.0.1:1521:ORCL
username=orcl
password=orcl

4、编写代码

(1)entity

package com.guor.entity;
 
public class Student {
	private int id;
	private String name;
	private int age;
 
	...
}

 (2)mapper

package com.guor.mapper;
 
import com.guor.entity.Student;
 
public interface StudentMapper {
	public void addStudent(Student student);
 
	public Student queryStudentByStuNo(int id);
}

StudentMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.guor.mapper.StudentMapper">
	<select id="queryStudentByStuNo" parameterType="int" resultType="com.guor.entity.Student">
		select * from student where id = #{stuNo}
	</select>
	
	<insert id="addStudent" parameterType="com.guor.entity.Student">
		insert into student(id,name,age) values (#{id},#{name},#{age})
	</insert>
</mapper>

 (3)StudentService

package com.guor.service;
 
import com.guor.entity.Student;
 
public interface IStudentService {
	public void addStudent(Student student);
	public Student queryStudentByStuNo(int id);
}

StudentServiceImpl  

package com.guor.service.impl;
 
import com.guor.entity.Student;
import com.guor.mapper.StudentMapper;
import com.guor.service.IStudentService;
 
public class StudentServiceImpl implements IStudentService {
	private StudentMapper studentMapper;
	
	public void setStudentMapper(StudentMapper studentMapper) {
		this.studentMapper = studentMapper;
	}
 
	@Override
	public void addStudent(Student student) {
		studentMapper.addStudent(student);
	}
 
	@Override
	public Student queryStudentByStuNo(int id) {
		return studentMapper.queryStudentByStuNo(id);
	}
}

 (4)controller

package com.guor.controller;
 
import java.util.Map;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import com.guor.entity.Student;
import com.guor.service.IStudentService;
 
@Controller
@RequestMapping("studentController")
public class StudentController {
	@Autowired
	@Qualifier("studentService")
	private IStudentService studentService;
 
	public void setStudentService(IStudentService studentService) {
		this.studentService = studentService;
	}
 
	@RequestMapping("queryStudentByStuNo/{id}")//映射
	public String queryStudentByStuNo(@PathVariable("id") Integer id,Map<String,Object> map) {
		Student student = studentService.queryStudentByStuNo(id);
		map.put("student", student);
		return "result";
	}
}

(5)配置文件

<?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:context="http://www.springframework.org/schema/context"
       xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans.xsd
        http://www.springframework.org/schema/mvc
        http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context.xsd 
        http://www.springframework.org/schema/tx 
        http://www.springframework.org/schema/tx/spring-tx.xsd">
	
	<!-- 扫描有注解的包 -->
	<context:component-scan base-package="com.guor.controller"></context:component-scan>
	
	<!-- 配置视图解析器(InternalResourceViewResolver) -->
	<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<property name="prefix" value="/views/"></property>
		<property name="suffix" value=".jsp"></property>
	</bean>
	
	<!-- springMVC基础配置、标配 -->
	<mvc:annotation-driven></mvc:annotation-driven>
	
	<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
		<property name="messageConverters">
			<list>
				<ref bean="mappingJacksonHttpMessageConverter" />
			</list>
		</property>
	</bean>
	<bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
		<property name="supportedMediaTypes">
			<list>
				<value>text/html;charset=UTF-8</value>
			</list>
		</property>
	</bean>
	
	<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
		<!-- <property name="exceptionAttribute" value = "ex"></property> 异常变量的默认值是exception-->
		<property name="exceptionMappings">
			<props>
				<!-- 相当于catch -->
				<prop key="java.lang.ArithmeticException">
					error
				</prop>
				<prop key="java.lang.NullPointException">
					error
				</prop>
			</props>
		</property>
	</bean>
</beans>

3、index.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
	<a href="studentController/queryStudentByStuNo/3">queryStudentByStuNo</a>
</body>
</html>

5、运行

springboot整合mybatis实现增删改查

? Java学习路线思维导图:Java学习路线思维导图

? Java学习路线配套文章:搬砖工逆袭Java架构师

? Java经典面试题大全:10万字208道Java经典面试题总结(附答案)

? 简介:Java领域优质创作者?、CSDN哪吒公众号作者✌ 、Java架构师奋斗者?

? 扫描主页左侧二维码,加入群聊,一起学习、一起进步 

? 欢迎点赞 ? 收藏 ⭐留言 ?    

springboot整合mybatis实现增删改查

添加微信,备注1024,赠送Java学习路线思维导图   

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/147881.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 微信自定义菜单url默认80端口问题解决

    微信自定义菜单url默认80端口问题解决

    2020年11月12日
  • 15个经典的Spring面试常见问题

    15个经典的Spring面试常见问题我自己总结的Java学习的系统知识点以及面试问题,已经开源,目前已经41k+Star。会一直完善下去,欢迎建议和指导,同时也欢迎Star:https://github.com/Snailclimb/JavaGuide这篇文章主要是想通过一些问题,加深大家对于Spring的理解,所以不会涉及太多的代码!这篇文章整理了挺长时间,下面的很多问题我自己在使用Spring的过程中也并没有…

  • realsense深度图像保存方法

    realsense深度图像保存方法一般使用realsense时会保存视频序列,当保存深度图像时,需要注意保存的图像矩阵的格式,不然可能造成深度值的丢失。在众多图像库中,一般会使用opencv中的imwrite()函数进行深度图像的保存。一般深度图像中深度值的单位是mm,因此一般使用np.uint16作为最终数据格式保存。例子:importnumpyasnpimportcv2deffun1(…

  • Linux下定时执行脚本实例

    Linux下定时执行脚本实例在Linux下我们用crontab来实现定期执行脚本。查看crontab    输入命令:cat/etc/crontabcrontab-u//设定特定用户的定时服务crontab-l//列出当前用户定时服务内容crontab-r//删除当前用户的定时服务crontab-e//编辑当前用户的定时服务在设定编辑之前都建议列出服务查看一下:crontab-l显示有一个已经设定好的…

  • day04 JavaScript高级程序设计 阅读总结

    day04 JavaScript高级程序设计 阅读总结《JavaScript高级程序设计》(第四版)阅读总结额,据说这本是前端er必看书籍,花了20个小时简单把这本书过了一下,目前暂时很少用到的东西我这一遍就没有过了,等以后要用的时候再回来继续学了。先来谈谈这本书的缺点,书籍前面章节用到了一些后面才讲到的东西,比如第三章讲symbol对象时,就用到了后面才讲的iterator和generator。然后就是感觉讲的有点太广了,而且基本没有课后习题,看过就是看过了,顶多自己花时间把书里面的例子都敲一遍。所以我建议应该和现代JavaScript教程一起食用。反

  • rabbitmq集群搭建_mongodb集群搭建

    rabbitmq集群搭建_mongodb集群搭建docker单容器部署创建桥接网络,用于容器间通信$dockernetworkcreatemq-network首先启动3个rabbitmq容器$dockerrun–namerabbit01\ -eRABBITMQ_SERVER_ADDITIONAL_ERL_ARGS=”-setcookieCOUBJLKLQCIAPKIQZGGJ”\ –hostnamerabbit01–networkmq-network\ -p5672:5672-p1567

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号