node.js对于数据库MySQL基本操作方法有哪些
本篇内容介绍了“node.js对于数据库MySQL基本操作方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
数据库MySQL基本操作(增删改查)
整个博客统一表结构为:
users表 四个字段id username password status,四个字段代表四列,其中id为自增列,status默认值为0,可选值0,1
id自增, username分别为zs,ls,wu password分别为:123456 abcdef 123abc status为0,1,1
#查询整张表的所有数据select*fromusers#查询指定列的所有数据selectusername,passwordfromusers#指定某列添加数据insertintousers(username,password)values('萧寂','1234')#指定某列修改数据updateuserssetusername="你好a",password="1234567",status=1whereid=2#根据id删除行deletefromuserswhereid=4#查询status为1的所有用户SELECT*FROMusersWHEREstatus=1#查询id大于2的所有用户SELECT*FROMusersWHEREid>2#查询username不等于admin的所有用户SELECT*FROMusersWHEREusername<>'admin'#使用AND来显示所有status为0,并且id小于3的用户:SELECT*FROMusersWHEREstatus=0ANDid<3#使用OR来显示所有status为1,或者username为zs的用户SELECT*FROMusersWHEREstatus=1ORusername='zs'#对users表中的数据,按照status字段进行升序排序SELECT*FROMusersORDERBYstatus;(升序排序在status后加上ASC效果等同)select*fromusersorderbystatusasc#根据id降序排序,降序排序使用desc关键字select*fromusersorderbyiddesc#多重排序对users表中的数据,先按照status字段进行降序排序,再按照username的字母顺序,进行升序排序SELECT*FROMusersORDERBYstatusDESC,usernameasc#查询id为1的数据返回的总条数selectcount(*)fromuserswhereid=1#将列名称从COUNT(*)修改为totalSELECTCOUNT(*)AStotalFROMusersWHEREid=1#给username列添加uname别名,给password列添加upwd别名selectusernameasuname,passwordasupwdfromusers
node.js项目中的增删改查
首先先执行命令初始化package.json包
npminit-y(文件名为英文,不能有空格、特殊字符或中文,否则报错)
mysql模块是托管于npm 上的第三方模块。它提供了在Node.js项目中连接和操作MySQL数据库的能力。
想要在项目中使用它,需要先运行如下命令,将mysql安装为项目的依赖包:
npminstallmysql或者npmimysql
上面操作完成后开始配置MySQL模块
配置MySQL模块
在使用mysql模块操作MySQL数据库之前,必须先对 mysql模块进行必要的配置,主要的配置步骤如下:
//导入MySQL模块constmysql=require("mysql")//建立与MySQL数据库的连接constdb=mysql.createPool({host:"127.0.0.1",//数据库的IP地址user:"root",//登录数据库的账号password:"admin",//登录数据库的密码database:"xiaoji"//指定要操作哪个数据库})
测试模块能否正常连接工作(执行运行命令node 文件名 或者 nodemon 文件名)
调用
db.query()
函数,指定要执行的SQL语句,通过回调函数拿到执行的结果
db.query("select1",function(err,results){//模块报错返回错误信息if(err)returnconsole.log(err.message);//运行成功console.log(results);})
测试成功的返回结果为:[ RowDataPacket { ‘1’: 1 } ]
查询表的SQL代码(表名和结构看第一行)
查询数据user表中所有的用户数据constsqlStr="select*fromusers"db.query(sqlStr,function(err,results){//查询失败if(err)returnconsole.log(err.message);//查询成功//注意如果执行的是select查询语句,则执行的结果是数组console.log(results);})
添加数据的SQL语句(两种方法)
//插入数据//向users表中新增数据,其中username为Spider-Man,password为pcc321//要插入到users表中的数据对象constuser={username:"Spider-Man",password:"pcc321"}//待执行的SQL语句,其中的?表示占位符constsqlStr="insertintostudent(student,card)values(?,?)"//使用数组的形式,依次为?占位符具体的值(result.affectedRows为影响的行数)db.query(sqlStr,[user.username,user.password],function(err,results){if(err)returnconsole.log(err.message);if(results.affectedRows==1){console.log("插入成功");}})//向表中新增数据时,如果数据对象的每个属性和数据表的字段一一对应,则可以通过如下方式快速插入数据://要插入到users表中的数据对象constuser={username:"Spider2-Man",password:"pcc321"}//待执行的SQL语句,其中的?表示占位符constsqlStr="insertintousersset?"db.query(sqlStr,user,function(err,results){if(err)returnconsole.log(err.message);if(results.affectedRows==1){console.log("插入成功");}})
修改数据的SQL语句(两种方法)
//修改表中的数据//向users表中更新的数据,其中username为Spider-Man,password为pcc321,id为5constuser={id:7,username:"xiao1jiao",password:"111222"}//待执行的sql语句,其中的?表示占位符constsqlStr="updateuserssetusername=?,password=?whereid=?"//使用数组的形式,依次为?占位符具体的值(result.affectedRows为影响的行数)db.query(sqlStr,[user.username,user.password,user.id],function(err,results){if(err)returnconsole.log(err.message);if(results.affectedRows==1){console.log("修改",user.id,"列成功");}})//修改表数据时,如果数据对象的每个属性和数据表的字段一一对应,则可以通过如下方式快速修改表数据//向users表中更新的数据,其中username为aaaa,password为1111,id为5constuser={id:5,username:"aaaa",password:"1111"}//待执行的sql语句,其中的?表示占位符constsqlStr="updateusersset?whereid=?"//使用数组的形式,依次为?占位符具体的值(result.affectedRows为影响的行数)db.query(sqlStr,[user,user.id],function(err,results){if(err)returnconsole.log(err.message);if(results.affectedRows==1){console.log("修改",user.id,"列成功");}})
删除数据的SQL语句
//在删除数据时,推荐根据id这样的唯一标识,来删除对应的数据。示例如下:constsqlStr="deletefromuserswhereid=?"//调用db.query(O)执行SQL语句的同时,为占位符指定具体的值//注意:如果SQL语句中有多个占位符,则必须使用数组为每个占位符指定具体的值//如果SQL语句中只有一个占位符,则可以省略数组db.query(sqlStr,5,function(err,results){if(err)returnconsole.log(err.message);//注意:执行delete语句之后,结果也是一个对象,也会包含affectedRows属性if(results.affectedRows==1){console.log("删除成功");}})
标记删除的情况
//标记删除//使用DELETE语句,会把真正的把数据从表中删除掉。为了保险起见,推荐使用标记删除的形式,来模拟删除的动作。//所谓的标记删除,就是在表中设置类似于status这样的状态字段,来标记当前这条数据是否被删除。//当用户执行了删除的动作时,我们并没有执行DELETE语句把数据删除掉,而是执行了UPDATE语句,将这条数据对应的status字段标记为删除即可。//标记删除:使用UPDATE语句替代DELETE语句;只更新数据的状态,并没有真正删除constsqlStr="updateuserssetstatus=?whereid=?"db.query(sqlStr,[0,7],function(err,results){if(err)returnconsole.log(err.message);if(results.affectedRows==1){console.log("标记删除成功");}})
注:文章所述的?占位符标记方法具有更好的兼容行,笔者曾经做过测试,使用原生SQL语句拼接字段后直接使用db.query语句执行,结果在处理富文本数据的时候报出了错误,需要进行字符转义处理。而使用?占位符则不会有这种情况出现。
“node.js对于数据库MySQL基本操作方法有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注主机评测网网站,小编将为大家输出更多高质量的实用文章!
下一篇:Java中怎么交换两个变量的值
winlogins.exe是什么文件?winlogins.exe是不是病毒
winsock2.6.exe是什么文件?winsock2.6.exe是不是病毒
WinDefendor.dll是什么文件?WinDefendor.dll是不是病毒
系统目录是什么文件?系统目录是不是病毒
wholove.exe是什么文件?wholove.exe是不是病毒
winn.ini是什么文件?winn.ini是不是病毒
w6oou.dll是什么文件?w6oou.dll是不是病毒
winduxzawb.exe是什么文件?winduxzawb.exe是不是病毒
wuammgr32.exe是什么文件?wuammgr32.exe是不是病毒
windiws.exe是什么文件?windiws.exe是不是病毒