Nodejs对postgresql基本操作的封装方法


Posted in NodeJs onFebruary 20, 2019

基于nodejs平台对postgresql的增删改查基本操作进行了封装,能满足基本的实际应用,比较复杂的SQL需另外实现。

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 style="font-family: Arial, Helvetica, sans-serif;">.</span>

以上这篇Nodejs对postgresql基本操作的封装方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

NodeJs 相关文章推荐
基于NodeJS的前后端分离的思考与实践(三)轻量级的接口配置建模框架
Sep 26 NodeJs
nodejs教程之制作一个简单的文章发布系统
Nov 21 NodeJs
nodejs爬虫抓取数据乱码问题总结
Jul 03 NodeJs
用nodejs的实现原理和搭建服务器(动态)
Aug 10 NodeJs
浅析 NodeJs 的几种文件路径
Jun 07 NodeJs
详解nodejs异步I/O和事件循环
Jun 07 NodeJs
CentOS 安装NodeJS V8.0.0的方法
Jun 15 NodeJs
浅谈nodejs中的类定义和继承的套路
Jul 26 NodeJs
Mac 安装 nodejs方法(图文详细步骤)
Oct 30 NodeJs
nodejs基于express实现文件上传的方法
Mar 19 NodeJs
Nodejs中获取当前函数被调用的行数及文件名详解
Dec 12 NodeJs
nodejs npm错误Error:UNKNOWN:unknown error,mkdir 'D:\Develop\nodejs\node_global'at Error
Mar 02 NodeJs
深入理解nodejs搭建静态服务器(实现命令行)
Feb 05 #NodeJs
Nodejs实现的操作MongoDB数据库功能完整示例
Feb 02 #NodeJs
基于Koa(nodejs框架)对json文件进行增删改查的示例代码
Feb 02 #NodeJs
用Electron写个带界面的nodejs爬虫的实现方法
Jan 29 #NodeJs
NVM安装nodejs的方法实用步骤
Jan 16 #NodeJs
nodeJS进程管理器pm2的使用
Jan 09 #NodeJs
NodeJS模块与ES6模块系统语法及注意点详解
Jan 04 #NodeJs
You might like
PHP新手上路(九)
2006/10/09 PHP
PhpStorm+xdebug+postman调试技巧分享
2020/09/15 PHP
JS JSON对象转为字符串的简单实现方法
2013/11/18 Javascript
jQuery实现滚动鼠标放大缩小图片的方法(附demo源码下载)
2016/03/05 Javascript
jQuery+php实时获取及响应文本框输入内容的方法
2016/05/24 Javascript
js设置和获取自定义属性的方法
2016/10/20 Javascript
浅析jQuery操作select控件的取值和设值
2016/12/07 Javascript
canvas绘制多边形
2017/02/24 Javascript
JavaScript屏蔽Backspace键的实现代码
2017/11/02 Javascript
10分钟上手vue-cli 3.0 入门介绍
2018/04/04 Javascript
JS实现的合并两个有序链表算法示例
2019/02/25 Javascript
vue中typescript装饰器的使用方法超实用教程
2019/06/17 Javascript
JavaScript 作用域实例分析
2019/10/02 Javascript
vue学习之Vue-Router用法实例分析
2020/01/06 Javascript
js实现移动端吸顶效果
2020/01/08 Javascript
[54:10]完美世界DOTA2联赛PWL S2 Magma vs FTD 第二场 11.29
2020/12/03 DOTA
python多线程抓取天涯帖子内容示例
2014/04/03 Python
Python实现在线程里运行scrapy的方法
2015/04/07 Python
简单了解Python下用于监视文件系统的pyinotify包
2015/11/13 Python
Python编码类型转换方法详解
2016/07/01 Python
Python2实现的LED大数字显示效果示例
2017/09/04 Python
Python实现连接MySql数据库及增删改查操作详解
2019/04/16 Python
python中的句柄操作的方法示例
2019/06/20 Python
Python Sympy计算梯度、散度和旋度的实例
2019/12/06 Python
Win10下配置tensorflow-gpu的详细教程(无VS2015/2017)
2020/07/14 Python
html5与css3小应用
2013/04/03 HTML / CSS
餐饮业的创业计划书范文
2013/12/26 职场文书
论文指导教师评语
2014/04/28 职场文书
文明工地标语
2014/06/16 职场文书
员工三分钟演讲稿
2014/08/19 职场文书
协商一致解除劳动合同协议书
2014/09/14 职场文书
党员群众路线对照检查材料思想汇报
2014/09/17 职场文书
声乐专业大学生职业生涯规划书:理想的未来需要自己去打造
2014/09/20 职场文书
仲裁协议书
2014/09/26 职场文书
学生保证书
2015/01/16 职场文书
ORACLE中dbms_output.put_line输出问题的解决过程
2022/06/28 Oracle