node.js对于数据库MySQL基本操作方法有哪些

数据库MySQL基本操作(增删改查)

整个博客统一表结构为:users表 四个字段id username password status,四个字段代表四列,其中id为自增列,status默认值为0,可选值0,1id自增, username分别为zs,ls,wu password分别为:123456 abcdef 123abc status为0,1,1

#查询整张表的所有数据select * from users#查询指定列的所有数据select username,password from users#指定某列添加数据insert into users(username,password) values('萧寂','1234')#指定某列修改数据update users set username="你好a",password="1234567",status=1 where id=2#根据id删除行delete from users where id=4#查询status为1的所有用户SELECT *FROM users WHERE status=1#查询id 大于2的所有用户SELECT *FROM users WHERE id>2#查询username不等于admin的所有用户SELECT *FROM users WHERE username'admin'#使用AND来显示所有status为0,并且id 小于3的用户:SELECT * FROM users WHERE status=0 AND id<3#使用OR来显示所有status为1,或者username为zs的用户SELECT* FROM users WHERE status=1 OR username='zs'#对users表中的数据,按照status字段进行升序排序SELECT * FROM users ORDER BY status;(升序排序在status后加上ASC效果等同)select * from users order by status asc#根据id降序排序,降序排序使用desc关键字select * from users order by id desc#多重排序 对users 表中的数据,先按照status字段进行降序排序,再按照username的字母顺序,进行升序排序SELECT * FROM users ORDER BY status DESC,username asc#查询id为1的数据返回的总条数select count(*) from users where id=1#将列名称从COUNT(*)修改为totalSELECT COUNT(*) AS total FROM users WHERE id=1#给username列添加uname别名,给password列添加upwd别名select username as uname,password as upwd from users

node.js项目中的增删改查

首先先执行命令初始化package.json包

npm init -y  (文件名为英文,不能有空格、特殊字符或中文,否则报错)

mysql模块是托管于npm 上的第三方模块。它提供了在Node.js项目中连接和操作MySQL数据库的能力。
想要在项目中使用它,需要先运行如下命令,将mysql安装为项目的依赖包:

npm install mysql   或者  npm i mysql

上面操作完成后开始配置MySQL模块

配置MySQL模块

在使用mysql模块操作MySQL数据库之前,必须先对 mysql模块进行必要的配置,主要的配置步骤如下:

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

测试模块能否正常连接工作(执行运行命令node 文件名 或者 nodemon 文件名)

调用db.query()函数,指定要执行的SQL语句,通过回调函数拿到执行的结果

库宝AI 库宝AI

库宝AI是一款功能多样的智能伙伴助手,涵盖AI写作辅助、智能设计、图像生成、智能对话等多个方面。

库宝AI 109 查看详情 库宝AI

db.query("select 1", function (err, results) {    //模块报错返回错误信息    if (err) return console.log(err.message);    //运行成功    console.log(results);})

测试成功的返回结果为:[ RowDataPacket { ‘1’: 1 } ]

查询表的SQL代码(表名和结构看第一行)

查询数据user表中所有的用户数据const sqlStr = "select * from users"db.query(sqlStr, function (err, results) {    //查询失败    if (err) return console.log(err.message);    //查询成功    //注意如果执行的是select查询语句,则执行的结果是数组    console.log(results);})

添加数据的SQL语句(两种方法)

//插入数据//向users表中新增数据,其中username为Spider-Man,password为pcc321//要插入到users表中的数据对象const user = { username: "Spider-Man", password: "pcc321" }//待执行的SQL语句,其中的?表示占位符const sqlStr = "insert into student(student,card) values(?,?)"//使用数组的形式,依次为?占位符具体的值(result.affectedRows为影响的行数)db.query(sqlStr, [user.username, user.password], function (err, results) {    if (err) return console.log(err.message);    if (results.affectedRows == 1) {        console.log("插入成功");    }})//向表中新增数据时,如果数据对象的每个属性和数据表的字段一一对应,则可以通过如下方式快速插入数据://要插入到users表中的数据对象const user = { username: "Spider2-Man", password: "pcc321" }//待执行的SQL语句,其中的?表示占位符const sqlStr = "insert into users set ?"db.query(sqlStr, user, function (err, results) {    if (err) return console.log(err.message);    if (results.affectedRows == 1) {        console.log("插入成功");    }})

修改数据的SQL语句(两种方法)

//修改表中的数据//向users表中更新的数据,其中username为Spider-Man,password为pcc321,id为5const user = { id: 7, username: "xiao1jiao", password: "111222" }//待执行的sql语句,其中的?表示占位符const sqlStr = "update users set username=?,password=? where id=?"//使用数组的形式,依次为?占位符具体的值(result.affectedRows为影响的行数)db.query(sqlStr, [user.username, user.password, user.id], function (err, results) {    if (err) return console.log(err.message);    if (results.affectedRows == 1) {        console.log("修改", user.id, "列成功");    }})//修改表数据时,如果数据对象的每个属性和数据表的字段一一对应,则可以通过如下方式快速修改表数据//向users表中更新的数据,其中username为aaaa,password为1111,id为5const user = { id: 5, username: "aaaa", password: "1111" }//待执行的sql语句,其中的?表示占位符const sqlStr = "update users set ? where id=?"//使用数组的形式,依次为?占位符具体的值(result.affectedRows为影响的行数)db.query(sqlStr, [user, user.id], function (err, results) {if (err) return console.log(err.message);if (results.affectedRows == 1) {    console.log("修改", user.id, "列成功");}})

删除数据的SQL语句

//在删除数据时,推荐根据id这样的唯一标识,来删除对应的数据。示例如下:const sqlStr = "delete from users where id=?"//调用db.query(O)执行SQL语句的同时,为占位符指定具体的值//注意:如果SQL语句中有多个占位符,则必须使用数组为每个占位符指定具体的值//如果SQL语句中只有一个占位符,则可以省略数组db.query(sqlStr, 5, function (err, results) {    if (err) return console.log(err.message);    //注意:执行 delete语句之后,结果也是一个对象,也会包含 affectedRows属性    if (results.affectedRows == 1) {        console.log("删除成功");    }})

标记删除的情况

//标记删除//使用DELETE语句,会把真正的把数据从表中删除掉。为了保险起见,推荐使用标记删除的形式,来模拟删除的动作。//所谓的标记删除,就是在表中设置类似于status这样的状态字段,来标记当前这条数据是否被删除。//当用户执行了删除的动作时,我们并没有执行DELETE语句把数据删除掉,而是执行了UPDATE语句,将这条数据对应的status字段标记为删除即可。//标记删除:使用 UPDATE语句替代 DELETE语句;只更新数据的状态,并没有真正删除const sqlStr = "update users set status=? where id=?"db.query(sqlStr, [0, 7], function (err, results) {    if (err) return console.log(err.message);    if (results.affectedRows == 1) {        console.log("标记删除成功");    }})

注:文章所述的?占位符标记方法具有更好的兼容行,笔者曾经做过测试,使用原生SQL语句拼接字段后直接使用db.query语句执行,结果在处理富文本数据的时候报出了错误,需要进行字符转义处理。而使用?占位符则不会有这种情况出现。 

以上就是node.js对于数据库MySQL基本操作方法有哪些的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/259678.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
Composer如何移除一个不再需要的依赖包
上一篇 2025年11月4日 08:39:26
《空洞骑士:丝之歌》舔狗角色火了 想亲大黄蜂被扇
下一篇 2025年11月4日 08:39:29

相关推荐

  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • MySQL数据库不支持中文的解决办法

    接上一篇文章,在解决了mysql+flask环境配置问题之后,往数据库存中文字符串会报1366错误,提示不正确的字符。继而发现默认的mysql采用了latin1字符集,这种编码是不支持中文的。 如果想支持中文的话,需要设置一下mysql字符集。 众所周知utf-8是可以的,gbk也没问题,为了可扩展…

    用户投稿 2026年5月10日
    000
  • JavaScript Electron桌面应用

    答案:使用JavaScript开发%ignore_a_1%桌面应用需结合Web技术与Node.js,通过主进程管理窗口、渲染进程展示界面,并利用IPC通信,调用系统功能如文件对话框,最后用electron-builder打包发布,注意安全与进程职责分离。 用JavaScript开发Electron桌…

    2026年5月10日
    000
  • Go语言连接外部MySQL数据库:DSN配置与常见错误解析

    本文详细阐述了go语言使用`go-sql-driver/mysql`驱动连接外部mysql数据库的正确方法。重点介绍了数据源名称(dsn)的规范格式,特别是主机地址部分的配置,以避免常见的“getaddrinfow: the specified class was not found.”等网络解析错…

    2026年5月10日
    000
  • 后缀php怎么打开_php文件打开方式与运行环境搭建指南

    要打开PHP文件需根据用途选择方式:查看代码可用文本编辑器或IDE,运行则需服务器环境。推荐新手使用XAMPP、WAMP等集成环境,将文件放入htdocs目录后访问localhost;开发者可利用PHP内置服务器,命令行执行php -S localhost:8000运行;高级用户可手动配置Apach…

    2026年5月10日
    000
  • 如何安全有效地从外部网页获取HTML元素数据并应用于自身页面

    本教程旨在解决如何在不同域名下,通过javascript获取并使用另一个网页的html元素数据。文章将深入探讨同源策略的限制,并提供两种主要解决方案:使用` 在现代Web开发中,有时我们需要从外部网站获取特定的HTML内容或属性值,并将其整合到我们自己的网页中。例如,从XYZ.COM/B.html页…

    2026年5月10日
    000
  • 使用SMTP.js发送邮件:客户端集成、常见问题与最佳实践指南

    本文深入探讨了使用SMTP.js库在前端发送邮件时可能遇到的问题,特别是与Elastic Email集成时的挑战。我们将分析代码中常见的异步处理错误、条件函数定义陷阱,并提供修正后的代码示例和最佳实践。重点强调了正确处理Promise链、确保函数可访问性以及客户端邮件发送的安全考量,帮助开发者构建更…

    2026年5月10日
    000
  • 如何在不暴露密钥的情况下,在客户端创建 Stripe Payment Link

    本文介绍了在纯静态网站环境下,如何利用 Stripe Payment Link 实现商品售卖,并着重讨论了在不暴露 Stripe 密钥的前提下,客户端创建 Payment Link 的可行性。分析了直接在客户端使用密钥的风险,并提出了预先生成 Payment Link 或使用后端服务动态生成 Pay…

    2026年5月10日
    000
  • Windows用Prettier一键格式化乱码HTML代码

    首先确保HTML文件保存为UTF-8编码,使用文本编辑器另存为UTF-8格式;其次在命令行执行chcp 65001切换至UTF-8代码页后再运行Prettier;接着在VS Code中设置files.encoding为utf8并启用files.autoGuessEncoding;最后可通过Node.…

    2026年5月10日
    000
  • PHP动态网页数据库备份恢复_PHP动态网页MySQL数据库备份教程

    答案:PHP动态网页的MySQL数据库备份与恢复需通过定期导出SQL文件并安全存储来保障数据安全,核心方法包括使用mysqldump命令行工具实现高效灵活的自动化备份,利用phpMyAdmin图形化工具进行手动导出导入以降低操作门槛,以及通过PHP脚本调用系统命令将备份过程集成到应用中;恢复时可采用…

    2026年5月10日
    000
  • php怎么截取网页_php抓取网页内容的几种方法

    file_get_contents适用于静态页抓取,但受限于allow_url_fopen且无法执行JS;2. cURL支持自定义请求头、Cookie等,适合处理复杂HTTP请求;3. Guzzle作为现代PHP项目推荐方案,具备良好扩展性与异步支持;4. 动态渲染内容需借助Puppeteer或Se…

    2026年5月10日
    000
  • php登录怎么实现_php用户登录系统完整实现

    <blockquote>PHP用户登录系统的核心是安全验证与会话管理。首先创建POST提交的登录表单,避免敏感信息暴露;后端通过session_start()启动会话,使用trim()和htmlspecialchars()清理输入,防止XSS攻击;利用PDO预处理语句查询数据库,防止SQ…

    用户投稿 2026年5月10日
    000
  • 远程MySQL数据库连接指南:从本地PHP应用访问GCP实例数据库

    本文详细指导如何在本地php应用中连接到google cloud platform (gcp) 虚拟机实例上的远程mysql数据库。教程涵盖了数据库连接参数的配置、使用php pdo建立连接的方法、gcp环境下的网络配置要点,以及常见的安全和故障排除建议,旨在帮助开发者顺利实现跨环境的数据库通信。 …

    2026年5月10日
    000
  • HTMLAMP怎么做_加速移动页面实现教程

    答案:HTML AMP通过规范标签、禁用自定义JS、引入AMP JS库和缓存技术提升移动页面加载速度,需遵循AMP HTML标准并验证有效性,有助于SEO但非万能,未来将更开放并与PWA等融合。 HTML AMP 旨在加速移动页面加载速度,提升用户体验。简单来说,它通过限制某些 HTML 功能,并采…

    2026年5月10日
    000
  • 理解PHP服务器端请求与浏览器开发者工具的限制

    当PHP脚本使用file_get_contents等函数发起服务器端请求时,这些请求直接在服务器上执行,而非通过浏览器。因此,浏览器开发者工具的网络活动面板无法捕获和显示这些内部的服务器间通信,因为它仅监控浏览器自身发出的网络请求,对服务器内部处理过程无感知。 客户端请求与服务器端请求的本质区别 在…

    2026年5月10日
    000
  • 在PHP中实现MySQL数据插入时避免重复记录的策略

    本文将探讨在php应用中向mysql数据库插入数据时,如何有效避免重复记录的产生。针对当主键或唯一索引字段值已存在的情况,我们将介绍使用`insert ignore`语句的策略,以确保数据完整性并防止不必要的重复插入,从而简化数据管理逻辑。 引言:数据完整性与重复记录问题 在数据库管理中,数据完整性…

    2026年5月10日
    000
  • php实现哪些功能

    PHP是一种通用脚本语言,可用来实现广泛的功能,包括:动态Web开发:生成响应用户请求的动态 веб页面。内容管理系统(CMS):构建允许用户管理网站内容的CMS。电子商务:开发具有购物车、订单处理和支付网关集成的电子商务网站。服务器端编程:编写命令行脚本和工具。文件操作:创建、读取、写入和删除文件…

    2026年5月10日
    000
  • PHP 动态 SQL WHERE 子句构建:避免重复 AND 的策略

    本文探讨了在 php 中动态构建 sql 查询 `where` 子句时常见的“`where and`”语法错误及其解决方案。通过逐步构建条件字符串,确保第一个条件不带 `and`,后续条件正确使用 `and` 连接,从而生成符合 sql 规范的查询语句,提高代码的健壮性和可读性。 动态构建 SQL …

    2026年5月10日
    200
  • PHP中基于用户角色的页面访问控制实践

    本教程详细讲解如何在PHP应用程序中利用会话(Session)机制实现基于用户角色的页面访问控制。通过正确的session_start()调用、用户登录时的角色信息存储,以及在受保护页面进行严格的会话和角色类型检查,确保只有特定用户(如“manager”)才能访问指定页面,从而有效防止未经授权的访问…

    2026年5月10日
    100
  • JavaScript模块加载机制_JavaScript代码组织规范

    现代前端推荐使用ES Modules,通过import和export实现静态依赖管理,配合合理目录结构与命名规范提升可维护性,注意浏览器与Node.js的运行差异。 JavaScript 的模块加载机制和代码组织规范是现代前端开发中的核心基础。随着项目规模扩大,良好的模块化设计能提升代码可维护性、复…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信