koa+mysql+vue+socket.io全棧開發之數據訪問篇

来源:https://www.cnblogs.com/edwardloveyou/archive/2019/04/12/10693744.html
-Advertisement-
Play Games

後端搭起大體的框架後,接著涉及到的就是如何將數據持久化的問題,也就是對資料庫進行 CURD 操作。 關於資料庫方案, mongodb 和 mysql 都使用過,但我選用的是 mysql ,原因: 1. 目前為止 mysql 與 mongodb 性能相差不大,尤其是 mysql 8.0 版本,速度非常 ...


後端搭起大體的框架後,接著涉及到的就是如何將數據持久化的問題,也就是對資料庫進行 CURD 操作。

關於資料庫方案, mongodbmysql 都使用過,但我選用的是 mysql,原因:

  1. 目前為止 mysqlmongodb 性能相差不大,尤其是 mysql 8.0 版本,速度非常快,查詢數據是 mysql 更快,寫數據方面 mongodb 則更勝一籌;
  2. mysql 建立 關聯數據要更方便些,比如: 一對多,多對多的關係;
  3. mysql 作為關係型資料庫,數據一致性方面更好,尤其是事務用起來更順手;
  4. 本人對 sql 操作比較得心應手,畢竟大部分項目用得都是 mysql,而 mongodb 在正式些的項目上用的就少了,而且目前關係型資料庫也在進化, postgrepmysql 都已經支持 json了。

node-mysql

node-mysql 是用 sql 語句對 mysql 進行操作的庫, 並沒有使用 Sequelize 這種 orm。因為我對 sql 熟悉,原生開發效率高。

連接池

連接資料庫我選用 連接池的方式,這種方式能高效的利用資料庫連接

//dbPool.js
const mysql = require('mysql');
const dbconfig = require('../config/db');
const log = require('../common/logger');
let pool = null;

/**
 * get the connection pool of database
 * 獲取資料庫連接池
 */
exports.getPool = function () {
    if (!pool) {
        log.info("creating pool");
        pool = mysql.createPool(dbconfig);
    }
    return pool;
}

資料庫配置文件

emoji 格式要用 utf8mb4 格式存儲,所以這裡連接字元集選用 utf8mb4,當然客戶端和數據結果集 一樣也要設置為 utf8mb4

module.exports={
    host: "localhost",
    port: "3306",
    user: "root",
    password: "jeff",
    database: "chatdb",
    charset : 'utf8mb4',//utf8mb4才能保存emoji
    multipleStatements: true,// 可同時查詢多條語句, 但不能參數化傳值
    connectionLimit: 100 //連接數量
};

Dao的編寫

基本的代碼編寫方式如下,每個方法基本都是這麼一種流程,獲取資料庫連接,執行 sql 語句,返回結果,處理異常。

exports.queryInfo = function (params, callback){
    pool.query('select ...', params, function (error, result, fields) {
        if (error) {
          log(error);
          callback(false);
        }
        else callback(result)
    }); 
}

exportDao

這造成了一大堆重覆的樣板代碼,我們需要封裝它,用 JavaScript 高階函數特性 很容易就能實現,同時加上 Promise,調用時就能方便地用 async await 了,還有日誌記錄功能也加上。

const pool = require("./dbPool").getPool();
const log = require('../common/logger');

/**
 * export named query function
 */
const exportDao = opts => Object.keys(opts).reduce((next, key) => {
    next[key] = (...args) => new Promise((resolve, reject) => {
        if (opts[key]) args.unshift(opts[key]);
        log.info('====== execute sql ======')
        log.info(args);
        pool.query(...args, (err, result, fields) => {// fields is useless
            if (err) reject(err)
            else resolve(result);
        });
    });
    return next;
}, {});

userDao文件為例,使用 exportDao 直接就能把裡面的 key-value 對象輸出為 以key 為方法名的dao方法,掛載到 module.exports 下。

const { exportDao } = require('./common');

//直接就exports裡面的key值對應的方法
module.exports = exportDao({
    sql: null,// 有些時候需要直接寫sql
    count: 'select count(*) as count from user where ?',
    getUser: 'select * from user where ?',
    insert: 'insert into user set ?',
    update: 'update user set ? where id = ?',
    delete: 'delete from user where ?'
});

/* 最終輸出格式
module.exports = {
  sql:() => {},
  count:() => {},
  ...
}*/

transaction

還有事務 transaction 的功能需要用到,來看一下 node-mysql 官方的例子,層層回調

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

-Advertisement-
Play Games
更多相關文章
  • 以下內容部分轉載自菜鳥教程 CSS層疊樣式表(Cascading Style Sheets) 內聯: 內嵌: 外部樣式文件: rel 屬性,規定當前文檔與被鏈接文檔/資源之間的關係。 優先順序: 內聯>內嵌>外部樣式文件 CSS選擇器 元素選擇器 類選擇器 ID選擇器 設置全局樣式 body{ ... ...
  • 一.pexels 提供大量高清尺寸,品質優良的攝影圖片,所有圖片都可以免費商用。網址:www.pexels.com 最好的免費圖片在一個叫pexels的地方,Pexels是使用的高質量照片庫的平臺。Pexels可以幫助設計師,博主和所有正在尋找圖像的人們找到可以在任何地方免費使用的精美照片。這意味著 ...
  • <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <meta http-e ...
  • 一、移動端預設樣式 ·IOS和Android下觸摸元素時出現半透明灰色遮罩 ·IOS按鈕圓角的問題 ·上下拉動滾動條時卡頓、慢 ·禁止複製、選中文本 ·旋轉屏幕時,字體大小調整的問題 二、移動端事件 2.1 基本使用 PC端事件仍然可以在移動端使用不過會存在一些問題,一會我們來闡述。 那麼移動端也有 ...
  • 把一個字元串中的字元重新排列生成新的字元串,返回新生成的字元串里沒有連續重覆字元的字元串個數.連續重覆只以單個字元為準 例如, aab 應該返回 2 因為它總共有6中排列 (aab, aab, aba, aba, baa, baa), 但是只有兩個 (aba and aba)沒有連續重覆的字元 (在 ...
  • 以相同的速度從開始到結束的過渡效果: Internet Explorer 10、Firefox、Opera 和 Chrome 支持 transition-timing-function 屬性。 Safari 支持替代的 -webkit-transition-timing-function 屬性。 註 ...
  • this關鍵字是JavaScript中最複雜的機制之一,是一個特別的關鍵字,被自動定義在所有函數的作用域中,但是相信很多JavaScript開發者並不是非常清楚它究竟指向的是什麼。聽說你很懂this,是真的嗎? 請先回答第一個問題:如何準確判斷this指向的是什麼?【面試的高頻問題】 ——————— ...
  • 一、viewport視口 1.1什麼是屏幕尺寸、屏幕解析度、屏幕像素密度? 屏幕尺寸:指屏幕的對角線的長度,單位是英寸,常見的屏幕尺寸有3.5、3.7、4.2、4.7、5.0、5.5、6.0等。 屏幕解析度:指在橫縱向上的像素點數,單位是px,1px=1個像素點。一般以縱向像素*橫向像素來表示一個手 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...