Node.js串連postgreSQL並進行資料操作_node.js

來源:互聯網
上載者:User

前言

PostgreSql是一個物件導向的關聯式資料庫,postgis是一個基於PostgreSql的空間資料庫外掛程式,主要用於管理地理空間資料。因此在GIS領域,廣泛使用PostgreSql作為空白間資料庫。

首先使用npm安裝資料庫連接模組:

npm install --save pg 

串連池建立

然後代碼中引入pg模組,並編寫資料庫配置:

var pg = require('pg');// 資料庫配置var config = {  user:"postgres", database:"ghost", password:"123456", port:5432, // 擴充屬性 max:20, // 串連池最大串連數 idleTimeoutMillis:3000, // 串連最大空閑時間 3s}

pg模組中有兩種資料庫連接方式,先講串連池模式,下面是建立串連池:

// 建立串連池var pool = new pg.Pool(config); 

傳入配置後就建立好了串連池。

查詢資料

查詢首先建立好串連,然後調用api進行查詢:

// 查詢pool.connect(function(err, client, done) {  if(err) { return console.error('資料庫連接出錯', err); } // 簡單輸出個 Hello World client.query('SELECT $1::varchar AS OUT', ["Hello World"], function(err, result) { done();// 釋放串連(將其返回給串連池) if(err) { return console.error('查詢出錯', err); } console.log(result.rows[0].out); //output: Hello World });});

輸出:

Hello World 

參數done是一個函數,調用這個函數可以將關閉串連(即將串連還給串連池)。

上面的是需要寫回調的非同步查詢,可以使用ES 7中await和async(但需安裝最新版本的pg,另外,需要使用7.2以上的nodejs,最好就是用最新的nodejs)最佳化代碼,如下:

// Async & Await 方式(需 node ^7.2.1,運行時使用 node --harmony-async-await index.js)var query = async () => {  // 同步建立串連 var connect = await pool.connect() try { // 同步等待結果 var res = await connect.query('SELECT $1::varchar AS OUT', ['Hello World By Async&Await']) console.log(res.rows[0].out) // 可以通過rows遍曆資料 } finally { connect.release() }}// 非同步進行資料庫處理query().catch(e => console.error(e.message, e.stack)); 

在升級了nodejs之後,執行代碼的時候,需要加參數--harmony-async-await

npm --harmony-async-await index.js 

當然,都支援到ES7了,ES6的Promise方法肯定是支援的,如下:

pool.connect().then(client=>{  client.query('SELECT $1::varchar AS OUT', ['Hello World By Promise']).then(res=>{ client.release() console.log(res.rows[0].out) }).catch(e => { client.release() console.error('query error', e.message, e.stack) })})

插入、修改、刪除資料

插入、修改、刪除資料和查詢的差不多

// 在表test中插入、修改、刪除資料,共兩個欄位 (name, age)pool.connect().then(client=>{  // insert 資料 client.query("INSERT INTO test(name, age) VALUES($1::varchar, $2::int)", ["xiaoming","20"]).then(res=>{ console.log("Insert Success") // 如果是自增ID,有傳回值的,在res裡 return res; }).then(res=>{ // 查詢xiaoming return client.query("Select * FROM test WHERE name = $1", ["xiaoming"]); }).then(res=>{ // 輸出結果,看是否插入成功 console.log(res.rows[0]) }).then(res=>{ // update 資料,將age改為21 return client.query("UPDATE test SET age=$1 WHERE name=$2", [21, "xiaoming"]) }).then(res=>{ // 再查詢一次xiaoming return client.query("Select * FROM test WHERE name = $1", ["xiaoming"]); }).then(res=>{ // 再輸出結果,看是否改為了21 console.log(res.rows[0]) }).then(res=>{ // 刪除資料 client.query("DELETE FROM test WHERE name=$1", ["xiaoming"]) }).then(res=>{ // 最後再查詢一次xiaoming res = client.query("Select * FROM test WHERE name = $1", ["xiaoming"]); // 釋放串連 client.release() return res }).then(res=>{ // 再輸出結果,沒資料 undefined console.log(res.rows[0]) })})

上面插入、更新裡代碼都沒有進行錯誤處理,按道理是要加的,但如果要加try...catch...的話,就太麻煩了(畢竟只是樣本).

事件監聽

可以添加error事件方法監聽串連池情況

pool.on("error", function(err, client){  console.log("error --> ", err)})

現在串連池的最大空閑時間是3s,也就是3s還沒使用串連,就釋放串連,可將這個時間設定得長一些,比如30s,這就讓我們有足夠的時間關掉資料庫進行測試(與資料庫連接一斷開,這個事件就被觸發了,生產環境中,可以用來寫日誌啊、發郵件簡訊通知什麼的。。。)。

另外,還可以監聽acquire和connect事件,前者在串連被用戶端擷取時觸發,後者在串連產生以及用戶端與資料庫互動時觸發。

pool.on('acquire', function (client) {  console.log("acquire Event")})pool.on('connect', function () {  console.log("connect Event")})

不使用串連池的用戶端

不使用串連池時,直接建立用戶端即可:

var client = new pg.Client(); 

串連池只是用來管理(緩衝)串連(即用戶端)的,查詢之類的方法跟它沒關係。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能有一定的協助,如果有疑問大家可以留言交流。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.