在Node.js项目中使用node-postgres连接postgres以及报错指南

什么是node-postgres

官方文档

nodepostgres是node.js模块的集合,用于与PostgreSQL数据库接口。它支持回调、promise、async/await、连接池、准备好的语句、游标、流式结果、C/C++绑定、富类型解析等等!就像PostgreSQL本身一样,它有很多功能:本文档旨在让您快速、正确地运行。它还试图为更高级和边缘案例主题提供指南,使您能够从node.js充分利用PostgreSQL的功能。

如何使用它?

下载依赖
复制代码
npm install pg

执行语句

复制代码
import { Client } from 'pg'

const client = new Client({
  host: 'my.database-server.com',
  port: 5334,
  database: 'database-name',
  user: 'database-user',
  password: 'secretpassword!!',
})
await client.connect()
 
const res = await client.query('SELECT $1::text as message', ['Hello world!'])
console.log(res.rows[0].message) // Hello world!
await client.end()

问题解决汇总

报错1:postgres db报错"err":{"type":"DatabaseError","message":"column "xxx报错点xxx" does not exist",

复制代码
"err":{"type":"DatabaseError","message":"column \"xxx报错点xxx\" does not exist",

解决方案

遇到这种报错,八成是你的sql句子拼的有问题,仔细检查去吧

举个栗子:

复制代码
const insertApp = await client.query(`INSERT INTO applications 
              (app_name ) 
              VALUES 
              ('${validResult.appName}') 
              ON CONFLICT (app_name) 
              DO NOTHING;
              `);
建议改成下面的写法
  • node-postgres参考文档

  • 字符串连接参数直接到查询文本可能(而且经常)导致sql注入漏洞。

  • node-postgres支持参数化查询,将查询文本和参数原原原本地传递给PostgreSQL服务器,更为安全

  • 如果参数化null和undefined,则两者都将被转换为null。

    const text = 'INSERT INTO users(name, email) VALUES(1, 2) RETURNING *'
    const values = ['brianc', 'brian.m.carlson@gmail.com']

    const res = await client.query(text, values)

今天就写到这里啦~
  • 小伙伴们,( ̄ω ̄( ̄ω ̄〃 ( ̄ω ̄〃)ゝ我们明天再见啦~~
  • 大家要天天开心哦

欢迎大家指出文章需要改正之处~

学无止境,合作共赢

欢迎路过的小哥哥小姐姐们提出更好的意见哇~~

相关推荐
摘星小杨11 小时前
安装nvm管理node.js,详细安装使用教程和详细命令
node.js·nvm
灋✘逞_兇12 小时前
Node.Js是什么?
服务器·javascript·node.js
归于尽19 小时前
回调函数在Node.js中是怎么执行的?
前端·javascript·node.js
GDAL20 小时前
多字节字符的字节被拆分到不同 chunk 中,导致解码失败
node.js
Jacob02341 天前
“Node.js 不行了”?性能争议中的误解与选择真相
后端·node.js
全宝1 天前
前端也能这么丝滑!Node + Vue3 实现 SSE 流式文本输出全流程
前端·javascript·node.js
天天进步20151 天前
前端工程化:Webpack从入门到精通
前端·webpack·node.js
实习生小黄2 天前
express 连接在线数据库踩坑
node.js·express
伍哥的传说2 天前
H3初识——入门介绍之常用中间件
前端·javascript·react.js·中间件·前端框架·node.js·ecmascript
超级土豆粉2 天前
npm 包 scheduler 介绍
前端·npm·node.js