日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

MyBatis-学习笔记01【01.Mybatis课程介绍及环境搭建】

發布時間:2024/9/30 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MyBatis-学习笔记01【01.Mybatis课程介绍及环境搭建】 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
  • Java后端 學習路線 筆記匯總表【黑馬程序員】
  • MyBatis-學習筆記01【01.Mybatis課程介紹及環境搭建】【day01】
  • MyBatis-學習筆記02【02.Mybatis入門案例】
  • MyBatis-學習筆記03【03.自定義Mybatis框架】
  • MyBatis-學習筆記04【04.自定義Mybatis框架基于注解開發】【day02】
  • MyBatis-學習筆記05【05.使用Mybatis完成CRUD】
  • MyBatis-學習筆記06【06.使用Mybatis完成DAO層的開發】
  • MyBatis-學習筆記07【07.Mybatis的連接池及事務】【day02】
  • MyBatis-學習筆記08【08.動態SQL】
  • MyBatis-學習筆記09【09.Mybatis的多表操作】
  • MyBatis-學習筆記10【10.JNDI擴展知識】
  • MyBatis-學習筆記11【11.Mybatis的緩存】【day02】
  • ???????MyBatis-學習筆記12【12.Mybatis注解開發】
  • 目錄

    01.mybatis課程介紹

    02.三層架構和ssm框架的對應關系

    03.jdbc操作數據庫的問題分析

    04.mybatis概述

    05.mybatis環境搭建-前期準備

    創建Maven工程

    創建數據庫表

    mybatis坐標

    pom.xml

    06.mybatis的環境搭建

    編寫User實體類

    編寫持久層接口IUserDao

    在resources文件夾下 新建SqlMapConfig.xml文件

    編寫IUserDao.xml

    mybatis環境搭建步驟總結

    07.環境搭建的注意事項


    01.mybatis課程介紹

    mybatis框架? ?共四天
    第一天:mybatis入門
    ?? ?mybatis的概述
    ?? ?mybatis的環境搭建
    ?? ?mybatis入門案例
    ?? ?自定義mybatis框架(主要的目的是為了讓大家了解mybatis中執行細節)
    第二天:mybatis基本使用
    ?? ?mybatis的單表crud操作
    ?? ?mybatis的參數和返回值
    ?? ?mybatis的dao編寫
    ?? ?mybatis配置的細節
    ?? ??? ?幾個標簽的使用
    第三天:mybatis的深入和多表
    ?? ?mybatis的連接池
    ?? ?mybatis的事務控制及設計的方法
    ?? ?mybatis的多表查詢
    ?? ??? ?一對多(多對一)
    ?? ??? ?多對多
    第四天:mybatis的緩存和注解開發
    ?? ?mybatis中的加載時機(查詢的時機)
    ?? ?mybatis中的一級緩存和二級緩存
    ?? ?mybatis的注解開發
    ?? ??? ?單表CRUD
    ?? ??? ?多表查詢

    02.三層架構和ssm框架的對應關系

    1、什么是框架?
    ?? ?它是我們軟件開發中的一套解決方案,不同的框架解決的是不同的問題。
    ?? ?使用框架的好處:框架封裝了很多的細節,使開發者可以使用極簡的方式實現功能。大大提高開發效率。
    2、三層架構
    ?? ?表現層:是用于展示數據的
    ?? ?業務層:是處理業務需求
    ?? ?持久層:是和數據庫交互的

    01三層架構

    03.jdbc操作數據庫的問題分析

    3、持久層技術解決方案
    ?? ?JDBC技術:
    ?? ??? ?Connection
    ?? ??? ?PreparedStatement
    ?? ??? ?ResultSet
    ?? ?Spring的JdbcTemplate:
    ?? ??? ?Spring中對jdbc的簡單封裝
    ?? ?Apache的DBUtils:
    ?? ??? ?它和Spring的JdbcTemplate很像,也是對Jdbc的簡單封裝

    ?? ?以上這些都不是框架
    ?? ??? ?JDBC是規范
    ?? ??? ?Spring的JdbcTemplate和Apache的DBUtils都只是工具類。

    04.mybatis概述

    4、mybatis的概述
    ?? ?mybatis是一個持久層框架,用java編寫的。
    ?? ?它封裝了jdbc操作的很多細節,使開發者只需要關注sql語句本身,而無需關注注冊驅動,創建連接等繁雜過程
    ?? ?它使用了ORM思想實現了結果集的封裝。

    ????ORM:Object Relational Mappging 對象關系映射
    ????????簡單的說:就是把數據庫表和實體類及實體類的屬性對應起來,讓我們可以操作實體類就實現操作數據庫表。
    ????????????user????????????User
    ????????????id????????????userId
    ????????????user_name????????userName

    ????今天我們需要做到:實體類中的屬性和數據庫表的字段名稱保持一致。
    ????????????user數據表????????User實體類
    ????????????id????????????id
    ????????????user_name????????user_name

    05.mybatis環境搭建-前期準備

    創建Maven工程

    若勾選的話,選擇普通的java工程

    ?

    創建數據庫表

    數據庫:eesy_mybatis

    DROP TABLE IF EXISTS `user`;

    CREATE TABLE `user` (
    ? `id` int(11) NOT NULL auto_increment,
    ? `username` varchar(32) NOT NULL COMMENT '用戶名稱',
    ? `birthday` datetime default NULL COMMENT '生日',
    ? `sex` char(1) default NULL COMMENT '性別',
    ? `address` varchar(256) default NULL COMMENT '地址',
    ? PRIMARY KEY ?(`id`)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

    insert ?into `user`(`id`,`username`,`birthday`,`sex`,`address`) values (41,'老王','2018-02-27 17:47:08','男','北京'),(42,'小二王','2018-03-02 15:09:37','女','北京金燕龍'),(43,'小二王','2018-03-04 11:34:34','女','北京金燕龍'),(45,'傳智播客','2018-03-04 12:04:06','男','北京金燕龍'),(46,'老王','2018-03-07 17:37:26','男','北京'),(48,'小馬寶莉','2018-03-08 11:44:00','女','北京修正');

    mybatis坐標

    mybatis官網:mybatis – MyBatis 3 | 簡介

    ???????

    <dependency>
    ? <groupId>org.mybatis</groupId>
    ? <artifactId>mybatis</artifactId>
    ? <version>x.x.x</version>
    </dependency>

    pom.xml

    <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.itheima</groupId><artifactId>day01_easy_01mybatis</artifactId><version>1.0-SNAPSHOT</version><packaging>jar</packaging><!--打包方式:jar包--><!--導入mybatis坐標--><dependencies><!--依賴--><dependency><!--mybatis必備--><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.4.5</version><!--最新版--></dependency><dependency><!--mybatis必備--><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.6</version></dependency><dependency><!--日志--><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.12</version></dependency><dependency><!--單元測試--><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version></dependency></dependencies> </project>

    06.mybatis的環境搭建

    編寫User實體類

    ?

    package com.itheima.domain;import java.io.Serializable; import java.util.Date;public class User implements Serializable {private Integer id;private String username;private Date birthday;private String sex;private String address;public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getUsername() {return username;}public void setUsername(String username) {this.username = username;}public Date getBirthday() {return birthday;}public void setBirthday(Date birthday) {this.birthday = birthday;}public String getSex() {return sex;}public void setSex(String sex) {this.sex = sex;}public String getAddress() {return address;}public void setAddress(String address) {this.address = address;}@Overridepublic String toString() {return "User{" +"id=" + id +", username='" + username + '\'' +", birthday=" + birthday +", sex='" + sex + '\'' +", address='" + address + '\'' +'}';} }

    編寫持久層接口IUserDao

    package com.itheima.dao;import com.itheima.domain.User;import java.util.List;/*** 用戶的持久層接口*/ public interface IUserDao {/*** 查詢所有用戶** @return*/List<User> findAll(); }

    在resources文件夾下 新建SqlMapConfig.xml文件

    SqlMapConfig.xml:文件名一般寫為SqlMapConfig.xml。

    <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd"> <!-- mybatis的主配置文件 --> <configuration><!-- 配置環境 --><environments default="mysql"><!-- 配置mysql的環境 --><environment id="mysql"><!-- 配置事務的類型 --><transactionManager type="JDBC"></transactionManager><!-- 配置數據源(連接池) --><dataSource type="POOLED"><!-- 配置連接數據庫的4個基本信息 --><property name="driver" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/eesy_mybatis"/><property name="username" value="root"/><property name="password" value="root"/></dataSource></environment></environments><!-- 指定映射配置文件的位置,映射配置文件指的是每個dao獨立的配置文件 --><mappers><mapper resource="com/itheima/dao/IUserDao.xml"/><!-- resource指定文件位置 --></mappers> </configuration>

    編寫IUserDao.xml

    <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.itheima.dao.IUserDao"><!--配置查詢所有--><select id="findAll" resultType="com.itheima.domain.User">select * from user</select> </mapper>

    mybatis環境搭建步驟總結

    07.環境搭建的注意事項

    5、mybatis的入門
    ?? ?mybatis的環境搭建
    ?? ??? ?第一步:創建maven工程并導入坐標
    ?? ??? ?第二步:創建實體類和dao的接口
    ?? ??? ?第三步:創建Mybatis的主配置文件 SqlMapConifg.xml
    ?? ??? ?第四步:創建映射配置文件 IUserDao.xml
    ?? ?環境搭建的注意事項:
    ?? ??? ?第一個:創建IUserDao.xml 和 IUserDao.java時,名稱是為了和我們之前的知識保持一致。
    ?? ??? ??? ?在Mybatis中它把持久層的操作接口名稱和映射文件也叫做:Mapper
    ?? ??? ??? ?所以:IUserDao 和 IUserMapper是一樣的。(Mapper==Dao)
    ?? ??? ?第二個:在idea中創建目錄的時候,它和包是不一樣的
    ?? ??? ??? ?包在創建時:com.itheima.dao是三級結構
    ?? ??? ??? ?目錄在創建時:com.itheima.dao是一級目錄
    ?? ??? ?第三個:mybatis的映射配置文件位置必須和dao接口的包結構相同
    ?? ??? ?第四個:映射配置文件的mapper標簽namespace屬性的取值必須是dao接口的全限定類名
    ?? ??? ?第五個:映射配置文件的操作配置(select),id屬性的取值必須是dao接口的方法名
    ? ? ? ? 好處:當我們遵從了第三、四、五點之后,我們在開發中就無須再寫dao的實現類。
    ?? ?mybatis的入門案例

    mybatis框架 共四天 第一天:mybatis入門mybatis的概述mybatis的環境搭建mybatis入門案例自定義mybatis框架(主要的目的是為了讓大家了解mybatis中執行細節) 第二天:mybatis基本使用mybatis的單表crud操作mybatis的參數和返回值mybatis的dao編寫mybatis配置的細節幾個標簽的使用 第三天:mybatis的深入和多表mybatis的連接池mybatis的事務控制及設計的方法mybatis的多表查詢一對多(多對一)多對多 第四天:mybatis的緩存和注解開發mybatis中的加載時機(查詢的時機)mybatis中的一級緩存和二級緩存mybatis的注解開發單表CRUD多表查詢 ----------------------------------------------------------- 1、什么是框架?它是我們軟件開發中的一套解決方案,不同的框架解決的是不同的問題。使用框架的好處:框架封裝了很多的細節,使開發者可以使用極簡的方式實現功能。大大提高開發效率。 2、三層架構表現層:是用于展示數據的業務層:是處理業務需求持久層:是和數據庫交互的 3、持久層技術解決方案JDBC技術:ConnectionPreparedStatementResultSetSpring的JdbcTemplate:Spring中對jdbc的簡單封裝Apache的DBUtils:它和Spring的JdbcTemplate很像,也是對Jdbc的簡單封裝以上這些都不是框架JDBC是規范Spring的JdbcTemplate和Apache的DBUtils都只是工具類 4、mybatis的概述mybatis是一個持久層框架,用java編寫的。它封裝了jdbc操作的很多細節,使開發者只需要關注sql語句本身,而無需關注注冊驅動,創建連接等繁雜過程它使用了ORM思想實現了結果集的封裝。ORM:Object Relational Mappging 對象關系映射簡單的說:就是把數據庫表和實體類及實體類的屬性對應起來讓我們可以操作實體類就實現操作數據庫表。user Userid userIduser_name userName今天我們需要做到:實體類中的屬性和數據庫表的字段名稱保持一致。user數據表 User實體類id iduser_name user_name 5、mybatis的入門mybatis的環境搭建第一步:創建maven工程并導入坐標第二步:創建實體類和dao的接口第三步:創建Mybatis的主配置文件 SqlMapConifg.xml第四步:創建映射配置文件 IUserDao.xml環境搭建的注意事項:第一個:創建IUserDao.xml 和 IUserDao.java時,名稱是為了和我們之前的知識保持一致。在Mybatis中它把持久層的操作接口名稱和映射文件也叫做:Mapper所以:IUserDao 和 IUserMapper是一樣的。(Mapper==Dao)第二個:在idea中創建目錄的時候,它和包是不一樣的包在創建時:com.itheima.dao是三級結構目錄在創建時:com.itheima.dao是一級目錄第三個:mybatis的映射配置文件位置必須和dao接口的包結構相同第四個:映射配置文件的mapper標簽namespace屬性的取值必須是dao接口的全限定類名第五個:映射配置文件的操作配置(select),id屬性的取值必須是dao接口的方法名好處:當我們遵從了第三、四、五點之后,我們在開發中就無須再寫dao的實現類。mybatis的入門案例第一步:讀取配置文件第二步:創建SqlSessionFactory工廠第三步:創建SqlSession第四步:創建Dao接口的代理對象第五步:執行dao中的方法第六步:釋放資源注意事項:不要忘記在映射配置中告知mybatis要封裝到哪個實體類中配置的方式:指定實體類的全限定類名 resultType="com.itheima.domain.User"mybatis基于注解的入門案例:把IUserDao.xml移除,在dao接口的方法上使用@Select注解,并且指定SQL語句同時需要在SqlMapConfig.xml中的mapper配置時,使用class屬性指定dao接口的全限定類名。明確:我們在實際開發中,都是越簡便越好,所以都是采用不寫dao實現類的方式。不管使用XML還是使用注解配置。但是Mybatis它是支持寫dao實現類的。 6、自定義Mybatis的分析:mybatis在使用代理dao的方式實現增刪改查時做什么事呢?只有兩件事:第一:創建代理對象第二:在代理對象中調用selectList自定義mybatis能通過入門案例看到類class Resourcesclass SqlSessionFactoryBuilderinterface SqlSessionFactoryinterface SqlSession 與50位技術專家面對面20年技術見證,附贈技術全景圖

    總結

    以上是生活随笔為你收集整理的MyBatis-学习笔记01【01.Mybatis课程介绍及环境搭建】的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。