使用nodejs操作postgresql

环境准备

1 navicat premium
2 postgresql 14

装完上述软件后,远程连接上之后如下:
在这里插入图片描述
自己建立一个用户表users,然后随机生成一些数据即可

步骤

这里我将项目放到了gticode里,可以下载下来使用
https://gitcode.net/wangbiao9292/nodejs-postgresql/-/tree/master

在这里插入图片描述
这里几个文件解释下:
1 node_modules 依赖
2 package-lock.json 锁定的版本
3 package.json 配置
4 pgsql.js postgresql用来连接数据库的配置
5 server.js 依赖express的配置

下面贴一下代码:
pgsql.js

var pg = require("pg");
class pgsql {
    pool;
    constructor() {
        this.pool = new pg.Pool({
            database: "demo", //数据库名称
            user: "postgres", //用户名
            password: "root", //密码
            port: 5432, //端口号
            // 扩展属性
            max: 20, // 连接池最大连接数
            idleTimeoutMillis: 3000 // 连接最大空闲时间 3s
        })
    }
    //查询数据
    searchData(sqlString,callback){
        this.pool.connect((err,client,done)=>{
            client.query(sqlString,(err,result)=>{
                console.log(result)
            })
        })
    }
}
module.exports = pgsql

server.js

const pgsql = require("./pgsql")
const express = require('express');
const app = express();
const port = 5422;

app.listen(port, () => console.log(`listening on http://localhost:${port}`));
 

/**
 * 根路径访问
 */
app.get("/",(req,res)=>{
    res.send("hello world")
})

/**
 * 获取用户表信息
 */
app.get("/user",(req,res)=>{
    var sqlString = "select * from users";
    var s = new pgsql();
    s.pool.connect((err,client,done)=>{
        client.query(sqlString,(err,result)=>{
            done();
            console.log(result.rows)
            res.send(result)
        })
    })
    
})

然后运行npm start
在这里插入图片描述
就可以通过接口取值了:
在这里插入图片描述
在这里插入图片描述

Node.js 中的 `pg-pool` 和 `pg` 是两个常用的用于 PostgreSQL 数据库操作的模块,而 `pg-util` 是对这些模块的一种封装和增强,它提供了一些额外的功能,如连接池管理、错误处理和通用工具等,使得在 Node.js 中使用 PostgreSQL 更加方便。 以下是使用 `pg-util` 进行封装的一些基本步骤: 1. 安装依赖:首先,你需要安装 `pg` 和 `pg-pool`。如果还没有安装,可以在命令行中运行: ``` npm install pg pg-pool pg-util ``` 2. 导入模块:在你的代码中,导入 `pg-pool` 和 `pg-util`: ```javascript const { Pool } = require('pg'); const { createPool } = require('pg-pool'); const util = require('pg-util'); ``` 3. 创建连接池:使用 `createPool` 函数创建一个连接池,`pg-util` 可能会提供一些定制选项: ```javascript const poolOptions = { user: 'your_username', host: 'localhost', database: 'your_database', password: 'your_password', port: 5432, // PostgreSQL 默认端口 max: 10, // 最大并发连接数 idleTimeoutMillis: 30000, // 连接空闲超时时间 }; const pool = await createPool(poolOptions); ``` 4. 错误处理:利用 `pg-util` 提供的错误处理方法,例如,可以使用 `util.queryStream` 来执行查询,并捕获错误: ```javascript async function runQuery(query) { try { const queryStream = await util.queryStream(pool, query); // 处理查询结果 } catch (err) { console.error(`Error executing query: ${err.message}`); } finally { // 关闭连接池 pool.end(); } } ``` 5. 封装方法:你可以封装一些常用的操作,比如查询、插入、更新等,这样代码会更简洁,便于维护: ```javascript async function getUser(id) { const query = util.format('SELECT * FROM users WHERE id = $1', id); return runQuery(query); } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李卓书

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值