Nodejs》》MySql

Node.js 操作MySQL数据库

文档

# 项目要先安装mysql包npm i mysql@xx   // 安装指定版本npm i mysql      // 默认安装最新版本
# 连接 mysq// 使用连接池连接const mysql = require('mysql')# 建立连接const db = mysql.createPool({host:'',             // 数据库的IP地址user:'root',         // 登录数据库的账号password:'密码',     // 密码database:'xxx'      //  指定要操作具体的数据库  })# 测试mysq连接是否正常db.query('select 1',(err,results)=>{if(err) return console.log(err.message)//只要打印出  【RowDataPacket {'1':1}】 的结果,就证明数据库连接正常	console.log(results)})# 插入数据
const user = {userName:'zen',age:33,gender:'男'}
//用英文 ? 占位符
const sqlstr = ' insert into users(userName , age, gender) values(?,?,?)'
// 使用数组的形式,依次为 ? 占位符指定具体的值 
db.query(sqlstr,[user.userName,user.age,user.gender],(err,results)=>{if(err) return console.log(err.message)if(results.affectedRows ===1){console.log('插入数据成功')}})# 插入数据的便捷方式  如果 插入的字段很多
# 向表中新增数据时,如果数据对象的每个属性和数据表的字段  一一对应,则可以通过如下方式 快速插入数据
const user = {userName:'zen',age:33,gender:'男'}
//用英文 ? 占位符
const sqlstr = ' insert into users set ?'
// 直接将数据对象当作占位符的值 
db.query(sqlstr,user,(err,results)=>{if(err) return console.log(err.message)if(results.affectedRows ===1){console.log('插入数据成功')}})# 查询数据  注意 注意  注意  如果执行的是 select 查询语句,则执行的结果是数组const sqlstr = ' select *  from  users'
db.query(sqlstr,,(err,results)=>{if(err) return console.log(err.message)console.log(results)})#  更新数据
const user = {id:1001,userName:'zen',age:33,gender:'男'}
//用英文 ? 占位符
const sqlstr = ' update  users set userName = ?, age=?, gender=? where id=?'
// 使用数组的形式,依次为 ? 占位符指定具体的值 
db.query(sqlstr,[user.userName,user.age,user.gender,user.id],(err,results)=>{if(err) return console.log(err.message)// 注意 执行 update语句之后,执行的结果,也是一个对象,可以通过affectedRows 判断是否更新成功if(results.affectedRows ===1){console.log('更新数据成功')}})#  更新数据便捷方式  跟插入类似  
# 更新表数据时,如果数据对象的每个属性和数据表的字段  一一对应,则可以通过如下方式 快速更新数据
const user = {id:1001,userName:'zen',age:33,gender:'男'}
//用英文 ? 占位符
const sqlstr = ' update  users set ? where id=?'
// 使用数组的形式,依次为 ? 占位符指定具体的值 
db.query(sqlstr,[user.userName,user.id],(err,results)=>{if(err) return console.log(err.message)// 注意 执行 update语句之后,执行的结果,也是一个对象,可以通过affectedRows 判断是否更新成功if(results.affectedRows ===1){console.log('更新数据成功')}})##  删除数据//用英文 ? 占位符
const sqlstr = ' delete users  where id=?'
//   注意  注意  注意  注意  如果SQL语句中有多个占位符,则必须使用数组为每个占位符指定具体的值如果sql语句中只有一个占位符,则可以省略数组
db.query(sqlstr,1001,(err,results)=>{if(err) return console.log(err.message)// 注意 执行 update语句之后,执行的结果,也是一个对象,可以通过affectedRows 判断是否更新成功if(results.affectedRows ===1){console.log('更新数据成功')}})

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

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

相关文章

金仓数据库常见问题(持续更新)

目录 1.查看大小是否敏感写参数,提示:未认可的配置参数 "case_sensitive" 2.sys_backup.sh init时提示can not connect the primary node 3.设置逻辑备份运行脚本时提示错误are not allowed to use this program (crontab) 4.修改表字段类…

Docker Buildx最佳实践:多架构镜像构建指南

文章目录为什么需要 Docker Buildx安装与启用 Docker Buildx创建多架构构建器实例构建多架构镜像优化构建性能调试多架构构建实战案例:构建 Go 应用多架构镜像总结Docker Buildx 是 Docker 官方推出的扩展工具,用于支持多平台镜像构建,简化跨…

你用的是什么键盘?

在电竞行业飞速发展的当下,游戏键盘作为玩家操作的核心载体,其性能表现直接影响着游戏体验与竞技结果。而赛卓电子推出的磁轴键盘专用芯片 SC4823,凭借一系列突破性的技术特性,正成为游戏键盘领域的性能革新者。​对于游戏玩家而言…

Activiti 中各种 startProcessInstance 接口之间的区别

前言在用 RuntimeService 接口启动流程实例时,总是分不清楚不同 startProcessInstanceXXX 接口之间的区别,这篇文章基于 Activiti 7.0.0.GA 版本,对这一类接口进行一个梳理和归类。详解接口列表RuntimeService 接口中以 startProcessInstance…

新手BUG:函数中 static 变量的赋值语句只会执行一次

在 C 函数中使用 static 变量时,很多新手会陷入一个认知误区:认为变量的初始化语句会在每次函数调用时执行。比如在bool funcA() { // Q:多次调用funcA,funcB会被执行几次?// A:1次static bool value func…

Python 基础详解:数据类型(Data Types)—— 程序的“数据基石”

一、引言:为什么数据类型如此重要?在 Python 编程中,数据类型决定了:数据的存储方式可以对数据执行的操作数据的取值范围不同类型之间的运算规则理解数据类型是编写正确、高效程序的基础。Python 是动态类型语言,虽然你…

WindowsLinux系统 安装 CUDA 和 cuDNN

Windows安装前的准备工作 检查硬件兼容性:确认电脑显卡为 NVIDIA GPU。通过快捷键 Win R 唤出“运行”,输入“control /name Microsoft.DeviceManager”唤出“设备管理器”,点击“显示适配器”查看是否有 NVIDIA 字样。 验证 CUDA 支持性&a…

工业数采引擎-通信链路SOCKET

通信库:DotNetty 封装实现:TcpServer、TcpClient、Udp TCP协议特性:面向连接协议;每个新连接都会创建独立的ChannelHandler实例;TcpHandler构造函数在每次客户端连接时触发 UDP协议特性:无连接协议&#…

PHP小白零基础入门(附视频教程)

概述 PHP是一种通用开源脚本语言,常用于服务器端Web开发,具有语法简单、上手快等特点。视频教程:https://pan.quark.cn/s/8f214c23301b 搭建开发环境: 选择集成工具:可选择XAMPP(支持Windows/Mac/Linux…

验证码等待时间技术在酒店自助入住、美容自助与社区场景中的应用必要性研究—仙盟创梦IDE

代码 代码 完整<!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>验证码倒计时</title><s…

Flask从入门到实战:基础、进阶、项目架构与接口测试

本文将带你从零开始掌握Flask框架&#xff0c;涵盖基础使用、进阶技巧、项目架构设计&#xff0c;并提供完整的接口测试客户端代码。 目录一、Flask基础入门1.1 Flask简介与安装1.2 第一个Flask应用1.3 路由与请求处理1.4 请求与响应处理二、Flask进阶使用2.1 模板引擎Jinja22.…

华为云产品图解

框架图核心说明: 1. 分层逻辑清晰 基础设施层(IaaS):提供最基础的计算(ECS/BMS)、存储(OBS/EVS)、网络(VPC/CDN)资源,是所有上层服务的 “物理底座”。 平台服务层(PaaS):基于 IaaS 构建,提供容器编排(CCE)、数据库(GaussDB)、大数据与 AI(ModelArts)、中…

Git 中如何回退到以前的提交记录?

回答重点要在 Git 中回退到以前的提交记录&#xff0c;你可以使用 git reset 命令。这个命令有三个常用选项来控制你想要回退的程度&#xff1a;1&#xff09; git reset --soft <commit> &#xff1a;仅修改 HEAD 指针&#xff0c;不修改索引和工作区内容。2&#xff09…

JavaWeb03——基础标签及样式(表单)(黑马视频笔记)

1.表单标签 及 表单属性表单标签是 &#xff1a;<form> 表单属性有&#xff1a;action 和 method&#xff1b;action属性&#xff1a;规定向何处发送表单数据。method属性&#xff1a;规定用什么方法发送数据。&#xff08;get和post&#xff09;get:在发送的url后面拼接…

STM32的SPI通信(软件读写W25Q64)

在了解完I2C通信后&#xff0c;不免会接触到到SPI通信。而一开始&#xff0c;可能会觉得两者好似没什么区别。为什么要学SPI呢&#xff0c;I2C和SPI有什么区别呢。为此我详细展开说说。1.什么是 SPI&#xff1f;SPI&#xff0c;全称 Serial Peripheral Interface&#xff0c;中…

子词分词器(Byte Pair Encoding + WordPiece)

参考文章&#xff1a;子词分词器BPE和WordPiece理解_wordpeice-CSDN博客 子词分词器BPE和WordPiece理解_wordpeice-CSDN博客 WordPiece 和 BPE 的区别-CSDN博客 点互信息&#xff08;PMI&#xff09;和正点互信息&#xff08;PPMI&#xff09;-CSDN博客 https://zhuanlan.z…

阿里招AI产品运营

AI产品运营&#xff08;岗位信息已经过jobleap.cn授权&#xff0c;可在csdn发布&#xff09;灵犀互娱 广州收录时间&#xff1a; 2025年08月05日职位描述负责AI技术在游戏行业的应用与落地&#xff0c;专注于海外市场的运营中台建设&#xff1b; 将结合AI技术与游戏行业特点&a…

Git 分支迁移完整指南(结合分支图分析)

基于分支图的当前状态分析 分支图关键信息解读​分支结构​&#xff1a; #mermaid-svg-gc9SPnwlbrM2FzHf {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-gc9SPnwlbrM2FzHf .error-icon{fill:#552222;}#mermaid-svg-…

小程序省市级联组件使用

背景。uni-data-picker组件用起来不方便。调整后级联效果欠佳&#xff0c;会关闭弹窗需要重新选择。解决方案。让cursor使用uniapp 原生组件生成懒加载省市级联 <template><view class"picker-cascader"><view class"cascader-label">&l…

Java技术栈/面试题合集(8)-Redis篇

场景 Java入门、进阶、强化、扩展、知识体系完善等知识点学习、性能优化、源码分析专栏分享: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/140870227 通过对面试题进行系统的复习可以对Java体系的知识点进行查漏补缺。 注: 博客: 霸道流氓气质-CSDN博…