Java程式員的日常—— POI與JDBC、Mockmvc與單元測試

来源:http://www.cnblogs.com/xing901022/archive/2016/09/05/5843892.html
-Advertisement-
Play Games

周日沒怎麼休息好,周一一天都迷迷糊糊的,不過還算是幹了不少的活。 總結一下,大致有以下幾點內容: 1 使用poi以及mysql jdbc實現了一個複雜excel的導入 2 基於工程原有的代碼,書寫spring mvc的業務代碼以及測試用例 使用POI以及jdbc POI是用於處理excel文件很常用 ...


周日沒怎麼休息好,周一一天都迷迷糊糊的,不過還算是幹了不少的活。

總結一下,大致有以下幾點內容:

  • 1 使用poi以及mysql jdbc實現了一個複雜excel的導入
  • 2 基於工程原有的代碼,書寫spring mvc的業務代碼以及測試用例

使用POI以及jdbc

POI是用於處理excel文件很常用的工具,如果你的excel是比較老的版本,記xls結尾的,那麼只使用poi就行了。如果是xlsx結尾的,還需要引入xssf的jar包。

參考maven的pom.xml配置:

    <!-- https://mvnrepository.com/artifact/org.apache.poi/poi -->
    <dependency>
      <groupId>org.apache.poi</groupId>
      <artifactId>poi</artifactId>
      <version>3.14</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml -->
    <dependency>
      <groupId>org.apache.poi</groupId>
      <artifactId>poi-ooxml</artifactId>
      <version>3.14</version>
    </dependency>

使用的話,這裡就簡單介紹下數據的讀取:

InputStream stream = new FileInputStream("絕對路徑\\文件名.xlsx");//獲得輸入流

XSSFWorkbook wb=new XSSFWorkbook(stream);//xlsx版本使用XSSFWorkbook

Sheet sheet1 = wb.getSheetAt(1);//獲取制定的sheet頁內容

for(int i=0,total = sheet1.getLastRowNum();i<total;i++){
    Row row = sheet1.getRow(i);//row.getCell(no)就能獲取指定列的內容
}

JDBC動態參數

使用JDBC還是很基礎的內容了,這裡使用動態sql動態拼接條件:

sql = "select id from scp_b where name=? and code=?";

相應的查詢:

PreparedStatement sta = conn.prepareStatement(sql);
sta.setString(1, "xxx";
sta.setString(2, "yyyy");
ResultSet rs = sta.executeQuery();
while(rs.next()){
    System.out.println(rs.getString("id"));
}
sta.close();

使用Mockmvc進行mvc的單元測試

以前沒有web mvc的單元測試經驗,所以這部分的內容還得繼續學習下,才能總結好。

不過,有一點還是需要明確的,就是單元測試。
單元測試,是最基本的程式驗證的方法。之前還流行過TDD測試驅動開發的軟體方法論,即需要先寫出測試用例,然後再去寫實現。這樣的好處就是在編寫實現之前,就明確知道輸入是什麼,輸出是什麼...不過,真正做到這點的,全國也沒有多少吧。大多是寫完實現,開發者自己補上測試用例,用來驗證一些簡單的場景而已。

@WebAppConfiguration
public class aaaTest extends BaseTest {
    
    @Autowired
    private WebApplicationContext wac;
    
    private MockMvc mockMvc;
    
    @Before
    public void setup() {
        this.mockMvc = MockMvcBuilders.webAppContextSetup(this.wac).build();
    }
    
    @Test
    public void OrderTendencyDataProfilingChart() throws Exception{
        this.mockMvc.perform(post("/a/b")
                .accept(MediaType.APPLICATION_JSON)
                .characterEncoding("UTF-8")
                .param("1", "2")
                .header(ApiTokenUtils._tokenName, ApiTokenUtils.getToken()))
        .andExpect(status().isOk())
        .andDo(new ResultHandler() {
            @Override
            public void handle(MvcResult result) throws Exception {
                result.getResponse().setCharacterEncoding("UTF-8");
                String content = result.getResponse().getContentAsString();
                System.out.println(content);
            }
        });
    }
}

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

-Advertisement-
Play Games
更多相關文章
  • 自定義可左右滑動、拖拽滑動的平面柱狀圖 在做這種樣式控制項之前,可先瀏覽我之前預研的控制項: A、自定義左右滑動ScrollViewer(可拖動滑動) B、自定義Bar柱狀圖 OK,現在說下控制項具體設計過程: 1)採用Grid佈局,這樣可以將Y軸的標題設置平均高度,X軸的柱子也可以平均。 當然X軸也會存 ...
  • 一個程式猿在夢中解決的 Bug 沒有人是不做夢的,在所有夢的排行中,白日夢最令人傷感。不知道身為程式猿的大家,有沒有睡了一覺,然後在夢中把睡之前代碼中怎麼也搞不定的 Bug 給解決的經歷?反正我是有過。 什麼是 AOP ? AOP 為 Aspect Oriented Programming 的縮寫, ...
  • 一、概述 WeakHashMap是Map的一種,根據其類的命令可以知道,它結合了WeakReference和HashMap的兩種特點,從而構造出了一種Key可以自動回收的Map。 前面我們已經介紹了WeakReference的特點及實現原理,以及HashMap的實現原理,所以我們本文重點介紹Weak ...
  • C++混合編程輔助工具, 方便將C++功能導出到腳本語言如Lua,Python中使用 ...
  • B - 大還是小? Time Limit:5000MS Memory Limit:65535KB 64bit IO Format: B - 大還是小? Description 輸入兩個實數,判斷第一個數大,第二個數大還是一樣大。每個數的格式為: [整數部分].[小數部分] 簡單起見,整數部分和小數部 ...
  • 繼續收集python3編碼問題相關資料 資料來源 鵬程的新浪博客(轉載)http://blog.sina.com.cn/s/blog_6d7cf9e50102vo90.html 這篇鵬程老師寫的關於python3的編碼的博客寫的特別的清楚,直接就摘入下來。供自己作為參考。 1.從位元組說起: 一個位元組 ...
  • 一.安裝之前先得知道怎麼下載吧: 一般網上找到的資料是到這裡就GG了的 --> http://spring.io/tools/sts/all 很明顯這點版本是不夠我們需要的,假如我們的eclipse是4.4.1怎麼辦.那麼奇淫技巧來了,我們自己拼接下載地址,點擊 進入我們需要的所有sts的版本,選擇 ...
  • Java有四種訪問許可權, 其中三種有訪問許可權修飾符,分別為private,public和protected,還有一種不帶任何修飾符。 下麵用表格的形式來展示四種訪問許可權之間的異同點,這樣會更加形象。表格如下所示: 同一個類 同一個包 不同包的子類 不同包的非子類 Private √ Default ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...