今日热搜:实战学习:聊聊Node.js怎么操作数据库

时间:2022-12-15 21:54:13       来源:转载


(资料图片)

本篇文章分享Node.js服务端实战,介绍一下Node操作数据库的方法,希望对大家有所帮助!

node.js极速入门课程:进入学习

连接数据库

const mysql = require("mysql")const db = mysql.createPool({  host: "localhost",  user: "root",  password: "123123123",  database: "test",  insecureAuth : true})const sql = `select *  from new_table`db.query(sql, (err, results) => {//   console.log(err)  if(err){    console.log(err.message)  }else{    console.log(results) //查询语句返回的是数组  }})
登录后复制

第一次连接数据库马上就报错了,还能怎么办呢,直接谷歌搜吧

ER_NOT_SUPPORTED_AUTH_MODE: Client does not support authentication protocol requested by server; consider upgrading MySQL client
登录后复制

大概意思是涉及到一些操作权限的问题,需要我们到数据库中执行这个语句,如果没报错的话大家可以跳过这个步骤。

ALTER USER "root"@"localhost" IDENTIFIED WITH mysql_native_password BY "这个地方替换成你的数据库密码";
登录后复制

在mysqlworkbrench中执行一下即可,然后回到我们的代码中继续执行连接数据库的操作

当输出这个语句的时候证明已经是连接成功的了

insert语句

const obj = {    name:"xiaoma",    password:"666666"}const insertSql = `insert into new_table (name,password) values (?,?)`db.query(insertSql,[obj.name,obj.password],(err,res)=>{    if(err){        console.log(err.message)    }else{        console.log(res)    }})
登录后复制

affectedRows为影响行,影响行数为1说明执行insert语句成功,所以我们这边可以修改一下insert成功的判断

if(res.affectedRows == 1){    console.log("insert success")}
登录后复制

简化新增sql

const obj = {    name:"xiaoma",    password:"123123"}const insertSql = `insert into new_table SET ?`db.query(insertSql,obj,(err,res)=>{    if(err){        console.log(err.message)    }    if(res.affectedRows == 1){        console.log("insert success")    }})
登录后复制

update语句

const updateSql = `Update  new_table set  name=? ,password=? where id=?`// const insertSql = `insert into new_table SET ?`db.query(updateSql,[obj.name,obj.password,obj.id],(err,res)=>{    if(err){        console.log(err.message)    }    if(res.affectedRows == 1){        console.log("insert success")    }})//简化写法const updateSql = `Update  new_table set ? where id=?`db.query(updateSql,[obj,obj.id],(err,res)=>{})
登录后复制

delete语句

const updateSql = `delete from  new_table  where id=?`db.query(updateSql,5,(err,res)=>{    if(err){        console.log(err.message)    }    if(res.affectedRows == 1){        console.log("insert success")    }})
登录后复制

更多node相关知识,请访问:nodejs 教程!

以上就是实战学习:聊聊Node.js怎么操作数据库的详细内容,更多请关注php中文网其它相关文章!

关键词: 连接数据库 相关文章 继续执行