使用Nodejs怎么操作postgresql?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

PG.js文件如下:
var pg = require('pg');
var conString = "postgres://username:password@localhost/databasename";
var client = new pg.Client(conString);
var PG = function(){
console.log("準備向****數據庫連接...");
};
PG.prototype.getConnection = function(){
client.connect(function (err) {
if (err) {
return console.error('could not connect to postgres', err);
}
client.query('SELECT NOW() AS "theTime"', function (err, result) {
if (err) {
return console.error('error running query', err);
}
console.log("hbdfxt數據庫連接成功...");
});
});
};
// 查詢函數
//@param str 查詢語句
//@param value 相關值
//@param cb 回調函數
var clientHelper = function(str,value,cb){
client.query(str,value,function(err,result){
if(err) {
cb("err");
}
else{
if(result.rows != undefined)
cb(result.rows);
else
cb();
}
});
}
//增
//@param tablename 數據表名稱
//@param fields 更新的字段和值,json格式
//@param cb 回調函數
PG.prototype.save = function(tablename,fields,cb){
if(!tablename) return;
var str = "insert into "+tablename+"(";
var field = [];
var value = [];
var num = [];
var count = 0;
for(var i in fields){
count++;
field.push(i);
value.push(fields[i]);
num.push("$"+count);
}
str += field.join(",") +") values("+num.join(",")+")";
clientHelper(str,value,cb);
};
//刪除
//@param tablename 數據表名稱
//@param fields 條件字段和值,json格式
//@param cb 回調函數
PG.prototype.remove = function(tablename,fields,cb){
if(!tablename) return;
var str = "delete from "+tablename+" where ";
var field = [];
var value = [];
var count = 0;
for(var i in fields){
count++;
field.push(i+"=$" +count);
value.push(fields[i]);
}
str += field.join(" and ");
clientHelper(str,value,cb);
}
//修改
//@param tablename 數據表名稱
//@param fields 更新的字段和值,json格式
//@param mainfields 條件字段和值,json格式
PG.prototype.update = function(tablename,mainfields,fields,cb){
if(!tablename) return;
var str = "update "+tablename+" set ";
var field = [];
var value = [];
var count = 0;
for(var i in fields){
count++;
field.push(i+"=$"+count);
value.push(fields[i]);
}
str += field.join(",") +" where ";
field = [];
for(var j in mainfields){
count++;
field.push(j+"=$"+count);
value.push(mainfields[j]);
}
str += field.join(" and ");
clientHelper(str,value,cb);
}
//查詢
//@param tablename 數據表名稱
//@param fields 條件字段和值,json格式
//@param returnfields 返回字段
//@param cb 回調函數
PG.prototype.select = function(tablename,fields,returnfields,cb){
if(!tablename) return;
var returnStr = "";
if(returnfields.length == 0)
returnStr = '*';
else
returnStr= returnfields.join(",");
var str = "select "+returnStr+ " from "+tablename+" where ";
var field = [];
var value = [];
var count = 0;
for(var i in fields){
count++;
field.push(i+"=$"+count);
value.push(fields[i]);
}
str += field.join(" and ");
clientHelper(str,value,cb);
};
module.exports = new PG();用法很簡單,如下:
var pgclient = require('./PG');// 引用上述文件
pgclient.getConnection();
// 調用上述四個函數即可
pgclient.save('userinfo',{'name': admin},cb);<span >.</span>關于使用Nodejs怎么操作postgresql問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注創新互聯行業資訊頻道了解更多相關知識。
網頁名稱:使用Nodejs怎么操作postgresql-創新互聯
分享路徑:http://www.yijiale78.com/article2/dchjic.html
成都網站建設公司_創新互聯,為您提供搜索引擎優化、微信小程序、網站導航、移動網站建設、面包屑導航、網站排名
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯