Mybaties簡單實例測試及註意問題

来源:https://www.cnblogs.com/springa/archive/2020/06/07/13061796.html
-Advertisement-
Play Games

IDEA下一個簡單的mybaties測試程式,適合初學者閱讀。 目錄結構及lib: 在src>main>java 下 根據資料庫表創建實體類:com.itheima.domain.User 註意:表欄位名和實體屬性要對應一致 package com.itheima.domain; import ja ...


IDEA下一個簡單的mybaties測試程式,適合初學者閱讀。

目錄結構及lib:

 

 

在src>main>java 下

根據資料庫表創建實體類:com.itheima.domain.User

註意:表欄位名和實體屬性要對應一致

package com.itheima.domain;

import java.io.Serializable;

public class User implements Serializable {

    private Integer id;
    private String sname;
    private Integer age;
    private String sex;
    private String phone;
    private Integer javascore;
    private String birth;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getSname() {
        return sname;
    }

    public void setSname(String sname) {
        this.sname = sname;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    public String getPhone() {
        return phone;
    }

    public void setPhone(String phone) {
        this.phone = phone;
    }

    public Integer getJavascore() {
        return javascore;
    }

    public void setJavascore(Integer javascore) {
        this.javascore = javascore;
    }

    public String getBirth() {
        return birth;
    }

    public void setBirth(String birth) {
        this.birth = birth;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", sname='" + sname + '\'' +
                ", age=" + age +
                ", sex='" + sex + '\'' +
                ", phone='" + phone + '\'' +
                ", javascore=" + javascore +
                ", birth='" + birth + '\'' +
                '}';
    }
}
View Code

創建dao方法:com.itheima.dao.IUserDao

package com.itheima.dao;

import com.itheima.domain.User;

import java.util.List;

public interface IUserDao {
    /*
    查詢所有操作
     */
    List<User>findAll();
}
View Code

---------------------------------------------------------

然後在src>main>resources下

創建dao方法的xml文件:resources>com.itheima.dao>IUserDao.xml

註意:目錄結構要與dao的介面方法目錄對應

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- namespace:命名空間,用於隔離sql,還有一個很重要的作用,後面會講 -->

<mapper namespace="com.itheima.dao.IUserDao">
    <select id="findAll" resultType="com.itheima.domain.User">select * from student</select>
</mapper>
View Code

在resources文件下配置SqlMapConfig.xml(自己命名,但一般都是這個):

<?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>
    <!-- 和spring整合後 environments配置將廢除-->
    <environments default="development">
        <environment id="development">
            <!-- 使用jdbc事務管理,事務控制由mybatis-->
            <transactionManager type="JDBC"/>
            <!-- 資料庫連接池,由mybatis管理-->
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.cj.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/school"/>
                <property name="username" value="root"/>
                <property name="password" value="root"/>
            </dataSource>
        </environment>
    </environments>

    <!-- 配置映射文件的位置 -->
    <mappers>
        <mapper resource="com/itheima/dao/IUserDao.xml"></mapper>
    </mappers>

</configuration>
View Code

導入相應的log4j.properties文件(必須)

log4j.rootLogger=WARN, stdout, R
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
# Pattern to output the caller's file name and line number.
#log4j.appender.stdout.layout.ConversionPattern=%5p [%t] (%F:%L) - %m%n
# Print the date in ISO 8601 format
log4j.appender.stdout.layout.ConversionPattern=%d [%t] %-5p %c - %m%n
log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=example.log
log4j.appender.R.MaxFileSize=100KB
# Keep one backup file
log4j.appender.R.MaxBackupIndex=1
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=%p %t %c - %m%n
# Print only messages of level WARN or above in the package com.foo.
log4j.logger.com.foo=WARN
View Code

 

以上完成後進行測試,編寫測試類:

在src>test下

創建測試方法類:

package com.itheima.test;



import com.itheima.dao.IUserDao;
import com.itheima.domain.User;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.InputStream;
import java.util.List;

public class MybatiesTest {
    public static void main(String[] args)throws  Exception {
        System.out.println("hello");
        //讀取配置文件
        InputStream in= Resources.getResourceAsStream("SqlMapConfig.xml");
        //創建SqlSessionFactory工廠
        SqlSessionFactoryBuilder builder=new SqlSessionFactoryBuilder();
        SqlSessionFactory factory=builder.build(in);
        //
        SqlSession sqlSession = factory.openSession();
        //
        IUserDao userDao = sqlSession.getMapper(IUserDao.class);

        //
        List<User> users = userDao.findAll();
        for (User user : users) {
            System.out.println(user);

        }
        //
        sqlSession.close();
        in.close();
    }
}

運行結果:

 一個簡單的mybaties測試程式完成。

-----------------------------------------------------------------------------------------------------------------------------------

遇到的錯誤及解決辦法:

1.Cause: org.apache.ibatis.builder.BuilderException: Error creating document instance.  Cause: org.xml.sax.SAXParseException; lineNumber: 25; columnNumber: 18; 元素類型為 "mapper" 的內容必須匹配 "EMPTY"。

 

 

 原因及解決方法:

 

 將空格換行刪除,然後改成這樣就能運行了

 

 2.

log4j:WARN No appenders could be found for logger (org.apache.ibatis.logging.LogFactory).

log4j:WARN Please initialize the log4j system properly.

 

 

 這個是沒有導入log4j.properties文件

 

 3.

 Cause: org.apache.ibatis.executor.ExecutorException: A query was run and no Result Maps were found for the Mapped Statement 'com.itheima.dao.IUserDao.findAll'.  It's likely that neither a Result Type nor a Result Map was specified.

 

 xml文件沒有指定resultType

 

4.mapper的resources值地址要用“/”

 

 5.SqlMapConfig.xml和dao實現類的xml文件頭

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 題目:學習static定義靜態變數的用法。 程式分析:無。 實例: 1 #include<stdio.h> 2 int main() 3 { 4 void fun(); 5 for(int i=0;i<3;i++) 6 fun(); 7 return 0; 8 } 9 void fun() 10 { ...
  • akka-cluster對每個節點的每種狀態變化都會在系統消息隊列里發佈相關的事件。通過訂閱有關節點狀態變化的消息就可以獲取每個節點的狀態。這部分已經在之前關於akka-cluster的討論里介紹過了。由於akka-typed里採用了新的消息交流協議,而系統消息的發佈和訂閱也算是消息交換,也受交流協 ...
  • 11 類型映射 11.1 引言 Chances are, you are reading this chapter for one of two reasons; you either want to customize SWIG's behavior or you overheard someon ...
  • 1. Java跨平臺原理(位元組碼文件、虛擬機) C/C++語言都直接編譯成針對特定平臺機器碼。如果要跨平臺,需要使用相應的編譯器重新編譯。 Java源程式(.java)要先編譯成與平臺無關的位元組碼文件(.class),然後位元組碼文件再解釋成機器碼運行。解釋是通過Java虛擬機來執行的。 位元組碼文件不 ...
  • 本教程源碼請訪問:tutorial_demo 一、概述 之前我們學習了AOP,然後通過AOP對我們的Apache Commons DbUtils實現單表的CRUD操作的代碼添加了事務。Spring有其自己的事務控制的機制,我們完全可以在項目中使用Spring自己的事務控制機制。 JavaEE體系進行 ...
  • 【寫在前面:一般能想出的方案】 <方案1:基於加密演算法本身的實現> 適合一部分有很強的演算法能力積累的同學,當然網上也有一些分享,但肯定不全面或者說沒有後續解答或支持。 話說也沒有想象得複雜,因為存在一些操作系統內置的組件,例如:openssl, 各種語言基本都可以實現符合openssl演算法規範的處理 ...
  • 深入理解:設計模式中的七大原則 一、單一原則 概念理解: 1個類只負責一個功能領域中的相應職責。 二、開閉原則(目標) 概念理解: 抽象是開閉原則的關鍵。 怎麼做: 面向介面、抽象類機制編程 三、里氏代換原則(基礎) 概念理解: 開閉原則的最重要實現方式之一;所有引用基類的地方必須能透明的使用其子類 ...
  • 設計模式中的關係總結 在軟體系統中,類並不是獨立存在的,類與類之間存在各種關係,對於不同類型的關係,UML提供了不同的表示方式。現在來總結梳理下: 一、關聯關係 類與類之間最常用的一種關係,是一種結構化的關係,用實線連接有關聯關係的對象所對應的類。java中,常將一個類的對象作為另一個類的成員變數。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...