当前位置: 首页 > news >正文

嘉兴做网站公司58同城黄页推广

嘉兴做网站公司,58同城黄页推广,贸易公司寮步网站建设哪家好,湖南建设人力资源网官网文章目录 一. Mybatis的简介1. 什么是ORM?2. 什么是持久层?3. Mybatis的作用 二. Mybatis环境搭建1. 搭建一个数据库2. 创建maven项目并导入相关依赖3. Mybatis相关插件安装4. Mybatis.cfg.xml核心配置文件 三. 基于ssm逆向工程的使用1. 配置generatorConfig.xml2.…

文章目录

  • 一. Mybatis的简介
    • 1. 什么是ORM?
    • 2. 什么是持久层?
    • 3. Mybatis的作用
  • 二. Mybatis环境搭建
    • 1. 搭建一个数据库
    • 2. 创建maven项目并导入相关依赖
    • 3. Mybatis相关插件安装
    • 4. Mybatis.cfg.xml核心配置文件
  • 三. 基于ssm逆向工程的使用
    • 1. 配置generatorConfig.xml
    • 2. 配置maven运行generator命令
  • 四. Mybatis增删改查案例

一. Mybatis的简介

Mybatis是一款优秀的ORM持久层框架,它支持自定义 SQL、存储过程以及高级映射(一对一,一对多)。Mybatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结果集的工作。

1. 什么是ORM?

Object Relation Mapping,对象关系映射。对象指的是Java对象,关系指的是数据库中的关系模型,对象关系映射,指的就是在Java对象和数据库的关系模型之间建立一种对应关系,比如用一个Java的Student类,去对应数据库中的一张student表,类中的属性和表中的列一一对应。Student类就对应student表,一个Student对象就对应student表中的一行数据。

2. 什么是持久层?

  • 持久层,顾名思义是完成持久化工作的代码块,也就是Date Access Object(Dao层)
  • 大多数情况下特别是企业级应用,数据持久化往往也就意味着将内存中的数据保存到磁盘上加以固化,而持久化的实现过程则大多通过各种关系数据库来完成。
  • 层是界限是十分明显的

3. Mybatis的作用

  • 简单易学:本身就很小且简单。没有任何第三方依赖,最简单安装只要两个jar文件+配置几个sql映射文件就可以了,易于学习,易于使用,通过文档和源代码,可以比较完全的掌握它的设计思路和实现。
  • 灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
  • 解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
  • 提供xml标签,支持编写动态sql。
  • 现在主流使用方法

二. Mybatis环境搭建

1. 搭建一个数据库

在这里插入图片描述

2. 创建maven项目并导入相关依赖

pom.xml依赖

<properties><maven.compiler.source>1.8</maven.compiler.source><maven.compiler.target>1.8</maven.compiler.target></properties><dependencies><!-- ********************** junit单元测试依赖 ********************** --><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><!-- ********************** Java Servlet API  ********************** --><dependency><groupId>javax.servlet</groupId><artifactId>javax.servlet-api</artifactId><version>4.0.0</version><scope>provided</scope></dependency><!-- ********************** Mybatis依赖 ********************** --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.4.5</version></dependency><!-- ********************** Mysql JDBC驱动 ********************** --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.44</version></dependency><!-- **********************  日志配置  ********************** --><!--记得修改mybatis.cfg.xml添加如下内容--><!--<setting name="logImpl" value="LOG4J2"/>--><!--核心log4j2jar包--><dependency><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-core</artifactId><version>2.9.1</version></dependency><dependency><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-api</artifactId><version>2.9.1</version></dependency><!--web工程需要包含log4j-web,非web工程不需要--><dependency><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-web</artifactId><version>2.9.1</version></dependency>
</dependencies><build><resources><!--解决mybatis-generator-maven-plugin运行时没有将XxxMapper.xml文件放入target文件夹的问题--><resource><directory>src/main/java</directory><includes><include>**/*.xml</include></includes></resource><!--解决mybatis-generator-maven-plugin运行时没有将jdbc.properites文件放入target文件夹的问题--><resource><directory>src/main/resources</directory><includes><include>jdbc.properties</include><include>*.xml</include></includes></resource></resources><plugins><plugin><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-maven-plugin</artifactId><version>1.3.2</version><dependencies><!--使用Mybatis-generator插件不能使用太高版本的mysql驱动 --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.44</version></dependency></dependencies><configuration><overwrite>true</overwrite></configuration></plugin></plugins></build>

jdbc.properties

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://47.100.191.44:3308/mybatis_ssm?useUnicode=true&characterEncoding=UTF-8
jdbc.username=test01
jdbc.password=test01

web.xml

<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"version="3.1"></web-app>

3. Mybatis相关插件安装

Free mybatis plugin

Free mybatis plugin的主要功能:
提供Mapper接口与配置文件中对应SQL的导航
编辑XML文件时自动补全
根据Mapper接口, 使用快捷键生成xml文件及SQL标签

在这里插入图片描述

Mybatis generator

Mybatis generator的主要功能:
它可以生成 MyBatis 的 Java 实体类、mapper.xml 文件以及对应的 Mapper 接口,极大地减少了开发人员手写 SQL 语句和映射实体类的工作量,提高了开发效率。

在这里插入图片描述

mybatis tools

mybatis tools的主要功能:
提供Mapper接口方法与XML配置文件中对应SQL自由切换导航。
提供Mapper接口方法调用明细。

在这里插入图片描述

maven helper

maven helper的主要功能:

  1. 显示依赖树。从 Maven pom.xml 文件中读取依赖关系,然后创建依赖树,可以通过 Maven Helper 插件的图形界面来查看依赖树,从而更好地理解项目的依赖关系。
  2. 查找冲突的依赖关系。如果项目中存在不兼容或冲突的依赖关系,Maven Helper 插件会发现这些问题,并将它们列出来,让你轻松修复这些错误。
  3. 解决依赖关系冲突。除了发现冲突的依赖关系外,Maven Helper 还可以自动解决这些问题。它通过检查不同的版本并选择最适合的版本来解决冲突的依赖关系。
  4. 管理 Maven 仓库。Maven Helper 还提供了一个简单的途径来管理和清理本地的 Maven 仓库。这个功能可以帮助你更高效地使用 Maven。

在这里插入图片描述

4. Mybatis.cfg.xml核心配置文件

Mybatis.cfg.xml

properties(属性) 标签:
开发者可通过properties属性来实现引用配置文件。这些属性都是可外部配置且可动态替换的。

setting(设置) 标签:
setting设置标签,这是Mybatis中极为重要的调整设置,它们会改变Mybatis的运行时行为。

environments(环境配置)标签:
MyBatis 可以配置成适应多种环境
不过要记住:尽管可以配置多个环境,但每个 SqlSessionFactory 实例只能选择一种环境。

typeAliases (类型别名)标签:
typeAliases类型别名是为java类型设置一个短的名字,存在的意义仅在于用来减少类完全限定名的冗余。java内置内建类型别名它们都不区分大小写,注意对基本类型名称重复采用的特殊命名风格。

mappers(映射器)标签:
注册绑定我们的Mapper文件;
注意:1.接口和它的Mapper配置文件必须同名
2. 接口和它的Mapper配置文件必须在同一个包下

<?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="jdbc.properties"/><settings><setting name="logImpl" value="LOG4J2"/></settings><!-- 别名 --><typeAliases><!--<typeAlias type="com.javaxl.model.Book" alias="Book"/>--></typeAliases><!-- 配置mybatis运行环境 --><environments default="development"><environment id="development"><!-- type="JDBC" 代表使用JDBC的提交和回滚来管理事务 --><transactionManager type="jdbc"/><!-- mybatis提供了3种数据源类型,分别是:POOLED,UNPOOLED,JNDI --><!-- POOLED 表示支持JDBC数据源连接池 --><!-- UNPOOLED 表示不支持数据源连接池 --><!-- JNDI 表示支持外部数据源连接池 --><dataSource type="POOLED"><property name="driver"value="${jdbc.driver}"/><property name="url"value="${jdbc.url}"/><property name="username" value="${jdbc.username}"/><property name="password" value="${jdbc.password}"/></dataSource></environment></environments><mappers><mapper resource="com/javaxl/mapper/BookMapper.xml"/></mappers>
</configuration>

三. 基于ssm逆向工程的使用

1. 配置generatorConfig.xml

generatorConfig.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN""http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd" >
<generatorConfiguration><!-- 引入配置文件 --><properties resource="jdbc.properties"/><!--指定数据库jdbc驱动jar包的位置--><classPathEntry location="D:\\maven\\mvn_repository\\mysql\mysql-connector-java\\5.1.44\\mysql-connector-java-5.1.44.jar"/><!-- 一个数据库一个context --><context id="infoGuardian"><!-- 注释 --><commentGenerator><property name="suppressAllComments" value="true"/><!-- 是否取消注释 --><property name="suppressDate" value="true"/> <!-- 是否生成注释代时间戳 --></commentGenerator><!-- jdbc连接 --><jdbcConnection driverClass="${jdbc.driver}"connectionURL="${jdbc.url}" userId="${jdbc.username}" password="${jdbc.password}"/><!-- 类型转换 --><javaTypeResolver><!-- 是否使用bigDecimal, false可自动转化以下类型(Long, Integer, Short, etc.) --><property name="forceBigDecimals" value="false"/></javaTypeResolver><!-- 01 指定javaBean生成的位置 --><!-- targetPackage:指定生成的model生成所在的包名 --><!-- targetProject:指定在该项目下所在的路径  --><javaModelGenerator targetPackage="com.xissl.model"targetProject="src/main/java"><!-- 是否允许子包,即targetPackage.schemaName.tableName --><property name="enableSubPackages" value="false"/><!-- 是否对model添加构造函数 --><property name="constructorBased" value="true"/><!-- 是否针对string类型的字段在set的时候进行trim调用 --><property name="trimStrings" value="false"/><!-- 建立的Model对象是否 不可改变  即生成的Model对象不会有 setter方法,只有构造方法 --><property name="immutable" value="false"/></javaModelGenerator><!-- 02 指定sql映射文件生成的位置 --><sqlMapGenerator targetPackage="com.xissl.mapper"targetProject="src/main/java"><!-- 是否允许子包,即targetPackage.schemaName.tableName --><property name="enableSubPackages" value="false"/></sqlMapGenerator><!-- 03 生成XxxMapper接口 --><!-- type="ANNOTATEDMAPPER",生成Java Model 和基于注解的Mapper对象 --><!-- type="MIXEDMAPPER",生成基于注解的Java Model 和相应的Mapper对象 --><!-- type="XMLMAPPER",生成SQLMap XML文件和独立的Mapper接口 --><javaClientGenerator targetPackage="com.xissl.mapper"targetProject="src/main/java" type="XMLMAPPER"><!-- 是否在当前路径下新加一层schema,false路径com.oop.eksp.user.model, true:com.oop.eksp.user.model.[schemaName] --><property name="enableSubPackages" value="false"/></javaClientGenerator><!-- 配置表信息 --><!-- schema即为数据库名 --><!-- tableName为对应的数据库表 --><!-- domainObjectName是要生成的实体类 --><!-- enable*ByExample是否生成 example类 --><!--<table schema="" tableName="t_book" domainObjectName="Book"--><!--enableCountByExample="false" enableDeleteByExample="false"--><!--enableSelectByExample="false" enableUpdateByExample="false">--><!--&lt;!&ndash; 忽略列,不生成bean 字段 &ndash;&gt;--><!--&lt;!&ndash; <ignoreColumn column="FRED" /> &ndash;&gt;--><!--&lt;!&ndash; 指定列的java数据类型 &ndash;&gt;--><!--&lt;!&ndash; <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" /> &ndash;&gt;--><!--</table>--><table schema="" tableName="t_mvc_Book" domainObjectName="Book"enableCountByExample="false" enableDeleteByExample="false"enableSelectByExample="false" enableUpdateByExample="false"><!-- 忽略列,不生成bean 字段 --><!-- <ignoreColumn column="FRED" /> --><!-- 指定列的java数据类型 --><!-- <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" /> --></table></context>
</generatorConfiguration>

2. 配置maven运行generator命令

生成JavaBean,sql映射文件和Mapper接口
在这里插入图片描述

四. Mybatis增删改查案例

Mapper接口

package com.xissl.biz;import com.xissl.model.Book;public interface BookBiz {int deleteByPrimaryKey(Integer bid);int insert(Book record);int insertSelective(Book record);Book selectByPrimaryKey(Integer bid);int updateByPrimaryKeySelective(Book record);int updateByPrimaryKey(Book record);
}

添加一个类去实现这个Mapper接口

package com.xissl.biz.impl;import com.xissl.biz.BookBiz;
import com.xissl.mapper.BookMapper;
import com.xissl.model.Book;/*** @author xissl* @create 2023-08-21 10:10*/
public class BookBizImpl implements BookBiz {private BookMapper bookMapper;public BookMapper getBookMapper() {return bookMapper;}public void setBookMapper(BookMapper bookMapper) {this.bookMapper = bookMapper;}@Overridepublic int deleteByPrimaryKey(Integer bid) {return bookMapper.deleteByPrimaryKey(bid);}@Overridepublic int insert(Book record) {return bookMapper.insert(record);}@Overridepublic int insertSelective(Book record) {return bookMapper.insertSelective(record);}@Overridepublic Book selectByPrimaryKey(Integer bid) {return bookMapper.selectByPrimaryKey(bid);}@Overridepublic int updateByPrimaryKeySelective(Book record) {return bookMapper.updateByPrimaryKeySelective(record);}@Overridepublic int updateByPrimaryKey(Book record) {return bookMapper.updateByPrimaryKey(record);}
}

Mybatis 工具类

package com.xissl.util;import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;public class SessionUtil {private static SqlSessionFactory sessionFactory;private static ThreadLocal<SqlSession> threadLocal = new ThreadLocal<SqlSession>();static {sessionFactory = new SqlSessionFactoryBuilder().build(SessionUtil.class.getResourceAsStream("/mybatis.cfg.xml"));}public static SqlSession openSession() {SqlSession session = threadLocal.get();if (null == session) {session = sessionFactory.openSession();threadLocal.set(session);}return session;}public static void main(String[] args) {SqlSession session = openSession();System.out.println(session.getConnection());session.close();
//        System.out.println(session.getConnection());}
}

测试

package com.xissl.demo;import com.xissl.biz.BookBiz;
import com.xissl.biz.impl.BookBizImpl;
import com.xissl.mapper.BookMapper;
import com.xissl.model.Book;
import com.xissl.util.SessionUtil;
import org.apache.ibatis.session.SqlSession;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;/*** @author xissl* @create 2023-08-21 10:18*/
public class demo01 {private SqlSession sqlSession;private BookBiz bookBiz;@Beforepublic void before(){System.out.println("执行测试方法前执行的代码块...");sqlSession = SessionUtil.openSession();BookBizImpl bookBiz = new BookBizImpl();BookMapper mapper = sqlSession.getMapper(BookMapper.class);bookBiz.setBookMapper(mapper);this.bookBiz = bookBiz;}@Afterpublic void after(){System.out.println("执行测试方法之后执行");}@Testpublic void test01(){System.out.println("测试方法");Book book = bookBiz.selectByPrimaryKey(25);System.out.println(book);}
}

运行结果:
在这里插入图片描述


文章转载自:
http://wanjiaagama.crhd.cn
http://wanjiazaffre.crhd.cn
http://wanjiamispickel.crhd.cn
http://wanjiaunreal.crhd.cn
http://wanjiavirago.crhd.cn
http://wanjiavarec.crhd.cn
http://wanjialock.crhd.cn
http://wanjiaguntz.crhd.cn
http://wanjiapilus.crhd.cn
http://wanjiabowknot.crhd.cn
http://wanjiacoit.crhd.cn
http://wanjiadenationalise.crhd.cn
http://wanjiaantecedence.crhd.cn
http://wanjiapycnidium.crhd.cn
http://wanjiaeuxenite.crhd.cn
http://wanjiarevaccinate.crhd.cn
http://wanjiacooner.crhd.cn
http://wanjiasouthabout.crhd.cn
http://wanjiamicrogram.crhd.cn
http://wanjiairrecusable.crhd.cn
http://wanjiametalogic.crhd.cn
http://wanjiapregnane.crhd.cn
http://wanjiacaponette.crhd.cn
http://wanjiasubcommission.crhd.cn
http://wanjialanuginous.crhd.cn
http://wanjiaultimatism.crhd.cn
http://wanjiajamming.crhd.cn
http://wanjiayamma.crhd.cn
http://wanjiaryot.crhd.cn
http://wanjialiberality.crhd.cn
http://wanjiaphantasmagory.crhd.cn
http://wanjiapollakiuria.crhd.cn
http://wanjiacomparable.crhd.cn
http://wanjiaantiparticle.crhd.cn
http://wanjiazealand.crhd.cn
http://wanjiaphonetist.crhd.cn
http://wanjiaacrocentric.crhd.cn
http://wanjiasolvent.crhd.cn
http://wanjiazek.crhd.cn
http://wanjiaestuarial.crhd.cn
http://wanjiagibraltar.crhd.cn
http://wanjiaperitricha.crhd.cn
http://wanjiaabdominous.crhd.cn
http://wanjiajuvenilia.crhd.cn
http://wanjialiturgic.crhd.cn
http://wanjiadraegerman.crhd.cn
http://wanjiatritagonist.crhd.cn
http://wanjianeuropterous.crhd.cn
http://wanjiaconcern.crhd.cn
http://wanjiaareopagitica.crhd.cn
http://wanjiarontgen.crhd.cn
http://wanjiaaerolith.crhd.cn
http://wanjiaremittal.crhd.cn
http://wanjiainculpable.crhd.cn
http://wanjiasynergism.crhd.cn
http://wanjiaflemish.crhd.cn
http://wanjiadredger.crhd.cn
http://wanjiawienie.crhd.cn
http://wanjiacarburetant.crhd.cn
http://wanjiaangor.crhd.cn
http://wanjialying.crhd.cn
http://wanjial2tp.crhd.cn
http://wanjiabespake.crhd.cn
http://wanjiaflaked.crhd.cn
http://wanjiadowncycle.crhd.cn
http://wanjiacanzona.crhd.cn
http://wanjiaunto.crhd.cn
http://wanjiajot.crhd.cn
http://wanjiaporteress.crhd.cn
http://wanjiacienaga.crhd.cn
http://wanjiasuccursal.crhd.cn
http://wanjiaoverburdensome.crhd.cn
http://wanjiaclearstarch.crhd.cn
http://wanjiarattlepated.crhd.cn
http://wanjiacassiopeia.crhd.cn
http://wanjiaovermatter.crhd.cn
http://wanjiaolio.crhd.cn
http://wanjianocturnality.crhd.cn
http://wanjiafritillaria.crhd.cn
http://wanjiaarose.crhd.cn
http://www.15wanjia.com/news/108025.html

相关文章:

  • 做网管要维护网站今日广州新闻最新消息
  • 给自己的网站做镜像网站如何建立独立网站
  • 前端开发可以做网站运营吗驻马店百度seo
  • 建立免费网站的步骤石家庄seo优化
  • 如何注销网站备案免费留电话的广告
  • 网站建设专家北京注安新浪舆情通
  • dedecms手机网站模板找片子有什么好的关键词
  • 高明专业网站建设哪家好温州百度推广公司电话
  • 如何入wordpressseo运营做什么
  • 深圳企业网站制作平台看啥网一个没有人工干预的网
  • seo优化是指通过研究搜索引擎排名规则杭州网站优化平台
  • 做装修的网站怎么做好免费测试seo
  • 郑州的做网站公司有哪些站长工具友链查询
  • 人和动物做的网站深圳最好的外贸seo培训
  • 中企动力上班怎么样河北seo公司
  • 网站 盈利晋城seo
  • seo网站沙盒期班级优化大师电脑版
  • 广告设计与制作专业课程seo推广专员工作好做吗
  • 你觉得什么是网络营销江苏seo推广
  • 怎么学网站设计网络推广十大平台
  • 企业官网建设 创意网站建设搜狗seo优化
  • 镇江网站建设流程搜索引擎排名优化seo课后题
  • 做网站app百度风云榜电视剧排行榜
  • 磁县网站设计公司西安网站建设维护
  • 怎么建视频网站免费的电脑系统优化软件
  • 商丘网站建设广告软文代写兼职
  • 外贸独立网站做仿品seo sem优化
  • 柳州做网站网站域名查询地址
  • 广告公关公司seo网站推广计划
  • 个人网站设计怎么做今日国内新闻最新消息大事