91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PostgreSQL Node.js怎么實現函數計算方法

發布時間:2021-04-20 09:47:15 來源:億速云 閱讀:159 作者:小新 欄目:web開發

這篇文章主要介紹了PostgreSQL Node.js怎么實現函數計算方法,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

js的作用是什么

1、能夠嵌入動態文本于HTML頁面。2、對瀏覽器事件做出響應。3、讀寫HTML元素。4、在數據被提交到服務器之前驗證數據。5、檢測訪客的瀏覽器信息。6、控制cookies,包括創建和修改等。7、基于Node.js技術進行服務器端編程。

技術棧

  • node.js

  • postgresql

  • nodemailer

controller +  services

編寫postgresql lib

不管異常還是正常都返回resolve,在resolve中處理結果,通過success字段去處理

const { Pool } = require('pg');
const config = require('../config/default.js');
const {
 database: {
 HOST,
 PORT,
 DATABASE,
 USERNAME,
 PASSWORD,
 },
} = config;
const pool = new Pool({
 port: PORT,
 host: HOST,
 user: USERNAME,
 password: PASSWORD,
 database: DATABASE,
});
/**
 * 
 * @param sql 接收的sql語句
 * @param {Array} values sql語句參數
 * @return { Object } { success: boolean, err || data }
 */
const query = async function( sql = 'select NOW()', values = []) {
 return new Promise(resolve => {
 pool.connect((err, client, release) => {
 if (err) {
 return console.error('Error acquiring client', err.stack)
 }
 const params = Array.isArray(values) ? [...values] : [values];
 client.query(sql, params, (error, result) => {
 release();
 if (error) {
  console.error('Error executing query', error.stack);
  resolve({
  success: false,
  error,
  });
 }
 resolve({
  success: true,
  data: result.rows,
 });
 });
 });
 });
}

module.exports = {
 query,
}

config配置文件如下

const config = {
 // 數據庫配置
 database: {
 DATABASE: 'databasename',
 USERNAME: 'root',
 PASSWORD: '123456',
 PORT: '3433',
 HOST: 'localhost',
 },
};

module.exports = config;

Controller

BaseController

首先編寫一個基類,用于封裝一些通用的方法

const pool = require('../lib/postgre'); // 導入封裝好的mysql庫
const { query } = pool; // 導入query方法
class BaseController {
 constructor() {
 }
 // 查詢表內所有數據(非刪除)
 async list() {
 const sql = `select * from ${this.table}`;
 return await query(sql);
 }
 async excute(sql, vals = []) {
 // 執行方法
 return await query(sql, vals);
 }
 // log 方法
 log({func, err}) {
 console.log(`excute function[${func}] occured error : ${err.message || err}`);
 }
}

module.exports = BaseController;

InqueryController

具體的業務邏輯Controller類

const BaseController = require('./BaseController'); // 獲得基類
// 繼承基類
class InqueryController extends BaseController {
 constructor() {
 super();
 this.table = 'data_table'; // 賦值table
 }
 // 可以重寫基類的方法,如果有業務需要
 async list() {
 const sql = `select * from ${this.table} ORDER BY created_at DESC `;
 return await this.excute(sql);
 }
 async getUnsendCustomer(vals) {
 const sql = `select * from ${this.table} where created_at > $1 ORDER BY created_at DESC`;
 // 統一在基類調用sql參數
 return await this.excute(sql, vals);
 }
 
}
module.exports = InqueryController;

Service

BaseService

統一封裝的方法,基類

// 需要綁定this的方法
const funcs = [
 'list',
]
class BaseService {
 constructor() {
 this.controller = null;
 // 循環遍歷綁定this, 在koa綁定route的時可用到
 funcs.forEach(item => {
  this[item] = this[item].bind(this)
 });
 }

 // 查詢方法
 async list(ctx) {
 if (!ctx) {
  return await this.controller.list();
 }
 // controller返回的是一個對象,success(成功為true, 失敗為false), data(成功則有此數據), err(失敗則有此對象)
 const { success: flag, data, error } = await this.controller.list();
 if (flag) {
  // success
  ctx.body = {
  data,
  code: 200,
  }
 } else {
  // failed
  ctx.body = {
  code: 500,
  error,
  };
 }
 }
}

module.exports = BaseService

InqueryService

具體的業務邏輯

// 導入基類
const BaseService = require('./BaseService');
// 導入對應的controller
const Controller = require('../controller/InqueryController');
// 獲取MailSender Service
const MailService = require('./MailSender');
const Helper = require('../util/Helper');

const funcs = [
 'unsendUser',
];
// 生成一次controller
const controller = new Controller();
class InqueryService extends BaseService {
 constructor() {
 super()
 // 綁定對應的controller
 this.controller = controller;
 funcs.forEach(item => {
  this[item] = this[item].bind(this);
 });
 }
 getMailOpts(i) {
 // you can use the data from database to combine the message
 const message = 'Hello world!';
 return return {
  message,
  // 可以從配置文件讀取或者oss
  to: 'xxxx@gmail.com',
  subject: 'Hello World',
 };
 }
 
 async unsendUser() {
 const list = await this.controller.list();
 if (list.length > 0) {
  const mailer = new MailService();
  const errorList = [];
  iterateList.forEach(async i => {
  const mailerOption = this.getMailOpts(i);
  const { success, ...rest } = await mailer.sendToAuitAdmin(mailerOption);
  if (!success) {
   errorList.push(rest);
  }
  });
  const lastestTime = iterateList[0].created_at;
  if (errorList.length === 0) {
  return {
   code: 200,
   message: 'Success',
  };
  }
 } else {
  return {
  code: 204,
  message: 'No user found',
  };
 }
 }
}
module.exports = new InqueryService();

index.js

函數計算的邏輯

const inqueryService = require('./services/InqueryService'); 
exports.handler = async function(event, context, callback) {
 const result = await inqueryService.unsendUser();
 callback(null, result);
};

感謝你能夠認真閱讀完這篇文章,希望小編分享的“PostgreSQL Node.js怎么實現函數計算方法”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

富裕县| 达日县| 章丘市| 穆棱市| 昂仁县| 游戏| 本溪| 华亭县| 田阳县| 绥宁县| 临泉县| 利辛县| 浑源县| 江孜县| 东兴市| 望奎县| 梅河口市| 达孜县| 金寨县| 钟山县| 汉中市| 榆中县| 宁波市| 铁岭市| 泰顺县| 西平县| 襄城县| 台州市| 天津市| 甘泉县| 封开县| 通化县| 大埔区| 浦北县| 东城区| 东乡族自治县| 白朗县| 吉安县| 吐鲁番市| 察隅县| 任丘市|