node操作MySQL数据库

news2025/1/12 7:40:27

本文节选自我的博客:node 操作 MySQL 数据库

  • 💖 作者简介:大家好,我是MilesChen,偏前端的全栈开发者。
  • 📝 CSDN主页:爱吃糖的猫🔥
  • 📣 我的博客:爱吃糖的猫
  • 📚 Github主页: MilesChen
  • 🎉 支持我:点赞👍+收藏⭐️+留言📝
  • 💬介绍:The mixture of WEB+DeepLearning+Iot+anything🍁

前言

本文介绍如何在node.js中使用MySQL

安装

mysql模块是托管于npm上的第三方模块,提供Node.js中操作数据库
npm i mysql

配置Mysql

注意这里需要在MySQL中提前建好库和表,建库建表方式自行搜索

// 1. 导入 mysql 模块
const mysql = require('mysql')
// 2. 建立与 MySQL 数据库的连接关系
const db = mysql.createPool({
  host: '127.0.0.1', // 数据库的 IP 地址
  user: 'root', // 登录数据库的账号
  password: '123456', // 登录数据库的密码
  database: 'my_schema', // 指定要操作哪个数据库
})

测试mysql模块

// 测试 mysql 模块能否正常工作
db.query('select 1', (err, results) =>{
  // mysql 模块工作期间报错了
  if(err) returnconsole.log(err.message)
  // 能够成功的执行 SQL 语句
  console.log(results)  //[ RowDataPacket { '1': 1 } ] 输出这个表示正常
})

查询表中的数据

// 查询 users 表中所有的数据
constsqlStr= 'select * from users'
db.query(sqlStr, (err, results) =>{
  // 查询数据失败
  if(err) returnconsole.log(err.message)
  // 查询数据成功
  // 注意:如果执行的是 select 查询语句,则执行的结果是数组
  console.log(results)
})

查询返回的数据是一个数组
4a393477-6dfc-458d-ab03-b030ec7be09e.png

向表中插入数据

// 向 users 表中,新增一条数据,其中 username 的值为 Spider-Man,password 的值为 pcc123
constuser= { username:'Spider-Man', password:'pcc123'}
// 定义待执行的 SQL 语句
constsqlStr= 'insert into users (username, password) values (?, ?)'
// 执行 SQL 语句
db.query(sqlStr, [user.username, user.password], (err, results) =>{
  // 执行 SQL 语句失败了
  if(err) returnconsole.log(err.message)
  // 成功了
  // 注意:如果执行的是 insert into 插入语句,则 results 是一个对象
  // 可以通过 affectedRows 属性,来判断是否插入数据成功
  if(results.affectedRows=== 1) {
    console.log('插入数据成功!')
  }
})

便捷写法

 constuser= { username:'Spider-Man2', password:'pcc4321'}
// 定义待执行的 SQL 语句
constsqlStr= 'insert into users set ?'
// 执行 SQL 语句
db.query(sqlStr, user, (err, results) =>{
  if(err) returnconsole.log(err.message)
  if(results.affectedRows=== 1) {
    console.log('插入数据成功')
  }
})

改数据

constuser= { id:5, username:'aaa', password:'000'}
// 定义 SQL 语句
constsqlStr= 'update users set username=?, password=? where id=?'
// 执行 SQL 语句
db.query(sqlStr, [user.username, user.password, user.id], (err, results) =>{
  if(err) returnconsole.log(err.message)
  // 注意:执行了 update 语句之后,执行的结果,也是一个对象,可以通过 affectedRows 判断是否更新成功
  if(results.affectedRows=== 1) {
    console.log('更新成功')
  }
}) 

便捷写法

constuser= { id:6, username:'aaaa', password:'0000'}
// 定义 SQL 语句
constsqlStr= 'update users set ? where id=?'
// 执行 SQL 语句
db.query(sqlStr, [user, user.id], (err, results) =>{
  if(err) returnconsole.log(err.message)
  if(results.affectedRows=== 1) {
    console.log('更新数据成功')
  }
}) 

删除

删除id为5的数据,这里传参可以不用[] ,因为只有一个参数

const sqlStr = 'delete from users where id=?'
db.query(sqlStr, 5, (err, results) => {
  if (err) return console.log(err.message)
  // 注意:执行 delete 语句之后,结果也是一个对象,也会包含 affectedRows 属性
  if (results.affectedRows === 1) {
    console.log('删除数据成功')
  }
})

标记删除(没有真删)

使用DELETE语句,会把真正的把数据从表中剧除掉。为了保险起见,推荐使用标记删除形式,所谓的标记删除,就是在表中设置类似于status这样的状态字段,来标记当前这条数据是否被删除,当用户执行了别除的动作时,我们并没有执行DELETE语句把数据别除掉,而是执行了UPDATE语句,将这条数据对应的status字段标记为删除即可。

constsqlStr= 'update users set status=? where id=?'
db.query(sqlStr, [1, 6], (err, results) =>{
  if(err) returnconsole.log(err.message)
  if(results.affectedRows=== 1) {
    console.log('标记删除成功')
  }
})

有任何疑问和想法,欢迎在评论区与我交流。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/756496.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

集群基础4——haproxy负载均衡mariadb

文章目录 一、环境说明二、安装配置mariadb三、安装配置haproxy四、验证 一、环境说明 使用haproxy对mysql多机单节点进行负载均衡。 主机IP角色安装服务192.168.161.131后端服务器1mariadb,3306端口192.168.161.132后端服务器2mariadb,3306端口192.168.…

【2023 年第二届钉钉杯大学生大数据挑战赛初赛】 初赛 A:智能手机用户监测数据分析 问题一Python代码分析

2023 年第二届钉钉杯大学生大数据挑战赛初赛 初赛 A:智能手机用户监测数据分析 问题一Python代码分析 1 题目 2023 年第二届钉钉杯大学生大数据挑战赛初赛题目 初赛 A:智能手机用户监测数据分析 一、问题背景 近年来,随着智能手机的产生&a…

STM32F10x外部中断/事件控制器(EXTI)应用

往期文章: STM32F1x固件库函数学习笔记(一) 文章目录 一、EXTI简介二、EXTI初始化结构体详解三、外部中断(EXTI)编程要点及例程参考文献 一、EXTI简介 外部中断/事件控制器,简称:EXTI&#x…

Jenkins打包、发布、部署

目录 前言 一、安装jdk 二、安装maven 三、安装git 四、安装jenkins 五、访问jenkins 六、创建用户 七、配置jenkins 八、执行 总结 前言 服务器:CentOS 7.9 64位 jdk:1.8 maven:3.9.1 git:git version 1.8.3.1 jenkins&a…

计算机中的数制与编码(二进制转换)

一、进制表示 1. 十进制表示 使用(0,1,2,…,9)十位数字表示,十进制运算时逢十进一。 2. 二进制表示 使用(0,1)两个数字表示,二进制运算时逢二进一。 3. 十六进制表示…

AIGC文生图:stable-diffusion-webui部署及使用

1 stable-diffusion-webui介绍 Stable Diffusion Web UI 是一个基于 Stable Diffusion 的基础应用,利用 gradio 模块搭建出交互程序,可以在低代码 GUI 中立即访问 Stable Diffusion Stable Diffusion 是一个画像生成 AI,能够模拟和重建几乎…

宝塔面板清理

查看磁盘使用情况时发现/dev/sda1满了,重启服务器也不行,瞎折腾了半天,才发现是宝塔的回收站占了较大的磁盘,于是按以下操作清理了下,就可以了 1、清除系统监控记录。打开宝塔面板后台,找到监控&#xff0c…

模拟面试2

1.说一说ArrayList的实现原理? ArrayList底层基于数组实现,内部封装了Object类型的数组,实现了list接口,通过默认构造器创建容器时,该数组被初始化为一个空数组,首次添加数据时再将其初始化为容量为10的数组…

变量生命符thread_local

thread_local是c11为线程安全引进的变量声明符。 thread_local是一个存储器指定符: 所谓存储器指定符,其作用类似命名空间,指定了变量名的存储期以及链接方式。同类型的关键字还有: static:静态或者线程存储期&…

2.我的第一个 JAVA 程序Helloword

对象:对象是类的一个实例,有状态和行为。例如,一条狗是一个对象,它的状态有:颜色、名字、品种;行为有:摇尾巴、叫、吃等。类:类是一个模板,它描述一类对象的行为和状态。…

前端videojs实现m3u8格式的直播

一、安装 npm install --save-dev video.js 二、引入 import videojs from "video.js"; import "video.js/dist/video-js.css"; 三、template 由于此处客户需要全屏至指定框大小,而不是全屏整个屏幕所以没用插件自带的全屏控件 隐藏自带全屏…

Unity 2DJoint 物理关节功能与总结

本文将以动图方式展示每个2D物理关节的效果,并解析部分重要参数的作用以及常见调配方式。 1.Distance Joint 2D(距离关节) 顾名思义是距离关节,以下为启用EnableCollision前后 关节使得两物体保持一定的距离,如果旋…

Apache (二十一)

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 目录 前言 一、概述 二、安装 1. yum安装 2. 编译安装 三、 目录结构 1. yum安装 2. 编译安装 四、虚拟主机头配置 1. 基本配置 2. 实现方式 五、配置文件语法检查 六、 …

MySQL [环境配置]

MySQL [环境配置] MySQL的下载sqlyog的下载 熟悉老陈的人, 都清楚我不喜欢写这些环境配置的博客 那为啥这次要写一下MySQL的环境配置呢? 因为我被这一个小小的环境配置困扰了很长时间, 淋过雨的人都想为别人撑一把伞, 我不希望我的铁汁们也被这个问题困扰 MySQL的下载 MySQL下…

3. 测试 - 软件测试生命周期 BUG 的级别和生命周期

目录 1. 软件测试的生命周期 2. 描述 BUG 2.1 为什么要进行描述 2.2 如何描述一个 BUG 练习描述 BUG:邮箱登录不上去 练习描述 BUG:ie下界面显示异常,界面文字有重叠 3. BUG 的级别 4. BUG 的生命周期 1. 软件测试的生命周期 软件的…

【kubernetes系列】Kubernetes之Ingress

概述 从前面的学习,我们可以了解到Kubernetes暴露服务的方式目前常见的只有三种:LoadBlancer Service、NodePort Service、Ingress;而我们需要将集群内服务提供外界访问就会面临以下几个问题: Pod 漂移问题 Kubernetes 具有强大…

ubuntu 不能检测到显卡信息

开始时:lspci | grep -i nvidia 01:00.0 VGA compatible controller: NVIDIA Corporation Device 2489 (rev a1) 01:00.1 Audio device: NVIDIA Corporation Device 228b (rev a1) 运行sudo update-pciids 运行 lspci | grep -i nvidia 找到显卡了

Linux - 进阶 NFS服务器搭建 详解实验操作

建立 NFS 服务器,使用客户端成功访问 # 搭建环境 server 为服务端, node1 为客户端 ( 客户端是通过 服务端克隆出来的机子,并改了 IP 和 主机名) IP 都显示出,并且双方能够 Ping 通 这样准备环…

顶尖公司是平均水平的100倍,惊讶吗?

行业顶尖公司人员平均能力水平,在行业平均水平的100倍之上! 程序员的超级榜样:美国integram公司13个人,最后被facebook用10亿美金收购 《中庸》人能一之己百之,人能十之己千之 趣讲大白话:百倍努力&#xf…

项目管理软件挑选诀窍:6个必须知道的关键点!

项目管理软件对于任何希望简化其操作和提高效率的组织来说都是一个有价值的工具。然而,市场上有这么多的选择,选择合适的软件可能是一项艰巨的任务。在本文中,我们将讨论如何选择满足您业务需求的项目管理软件。 1、确定你的挑战和限制 选择项…