使用nodejs操作postgresql

文章介绍了如何在安装navicat和postgresql后,通过Node.js建立数据库连接池,使用express框架创建API来获取用户表数据。示例代码展示了pgsql.js和server.js的实现,包括查询数据的方法和监听服务器端口。

环境准备

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
在这里插入图片描述
就可以通过接口取值了:
在这里插入图片描述
在这里插入图片描述

<think>好的,我现在需要帮助用户找到如何使用Node.js操作PostgreSQL的教程或示例代码,特别是连接和查询的部分。首先,我应该回顾用户提供的引用内容,看看有哪些相关的信息可以利用。 用户提供了四个引用,都是关于Node.js与PostgreSQL的连接和操作的。引用[2]和[4]提到了使用pg库建立连接池和进行查询的示例代码,引用[3]则提到了安装pg和knex这两个依赖项。而引用[1]虽然主要关于认证,但可能涉及到数据库操作的部分。 首先,我需要整理出连接数据库的基本步骤。根据引用[2]和[3],安装pg库是必须的,然后通过环境变量配置连接信息。引用[2]中的示例代码展示了如何使用Pool来创建连接池,并测试连接。同时,引用[4]中的代码片段演示了如何执行一个简单的查询,使用client.query方法,并在完成后释放连接。 接下来,用户可能需要了解如何执行查询,包括参数化查询以防止SQL注入。引用[2]和[4]中的示例都使用了参数化查询,比如SELECT $1::varchar AS OUT,这里用到了占位符$1,这是pg库支持的参数化方式,能够有效提升安全性。 此外,用户可能关心如何管理数据库连接,使用连接池的好处是什么。引用[2]提到连接池的配置和事件监听,比如connect和error事件,这有助于监控连接状态。连接池可以重用连接,减少频繁建立和关闭连接的开销,提高性能。 另外,引用[3]提到了knex这个SQL构造库,虽然用户的问题中没有明确提到,但可能作为扩展内容,可以简要介绍knex的用法,作为更高级的查询构建方式。 现在需要组织这些信息,结构清晰,分步骤说明如何连接和查询。首先安装依赖,然后配置连接池,接着执行查询,最后关闭连接。同时,要确保代码示例正确,比如使用环境变量,参数化查询,错误处理等。 需要注意用户提到的要求,比如行内数学表达式使用$...$格式,独立公式用$$...$$,但在这个问题中可能用不上数学公式,所以可能不需要处理这部分。另外,需要生成相关问题,可能涉及连接池优化、事务处理、ORM的使用等。 最后,确保回答中引用了正确的引用来源,比如在讲解连接池时引用[2],在参数化查询时引用[4]等。需要检查是否有遗漏的要点,比如错误处理、异步操作(比如使用async/await代替回调函数),这些也是用户可能关心的内容。</think>以下是为您整理的Node.js操作PostgreSQL完整指南,包含连接、查询等核心操作示例: ### 一、环境准备 1. 安装必要依赖(引用[3]): ```bash npm install pg knex ``` ### 二、建立数据库连接 ```javascript const { Pool } = require('pg'); // 配置连接池(引用[2][4]) const pool = new Pool({ user: 'your_username', host: 'localhost', database: 'your_database', password: 'your_password', port: 5432, max: 20, // 连接池最大连接数 idleTimeoutMillis: 30000 }); // 监听连接事件(引用[2]) pool.on('connect', () => console.log('PostgreSQL connected')); pool.on('error', (err) => console.error('Connection error:', err.stack)); ``` ### 三、执行查询操作 #### 1. 基本查询(引用[4]) ```javascript const query = async () => { const client = await pool.connect(); try { const res = await client.query('SELECT $1::text AS message', ['Hello PostgreSQL']); console.log(res.rows[0].message); // 输出:Hello PostgreSQL } finally { client.release(); } } ``` #### 2. 参数化查询(防止SQL注入) ```javascript const getUser = async (userId) => { const { rows } = await pool.query( 'SELECT * FROM users WHERE id = $1', [userId] ); return rows[0]; } ``` #### 3. 事务处理 ```javascript const transferFunds = async (from, to, amount) => { const client = await pool.connect(); try { await client.query('BEGIN'); await client.query('UPDATE accounts SET balance = balance - $1 WHERE id = $2', [amount, from]); await client.query('UPDATE accounts SET balance = balance + $1 WHERE id = $2', [amount, to]); await client.query('COMMIT'); } catch (err) { await client.query('ROLLBACK'); throw err; } finally { client.release(); } } ``` ### 四、使用Knex高级查询(引用[3]) ```javascript const knex = require('knex')({ client: 'pg', connection: { host: 'localhost', user: 'your_user', password: 'your_password', database: 'your_db' } }); // 链式查询示例 knex('users') .select('name', 'email') .where({ age: '> 25' }) .orderBy('created_at', 'desc') .then(users => console.log(users)); ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

李卓书

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

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

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

打赏作者

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

抵扣说明:

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

余额充值