users表 四个字段id username password status,四个字段代表四列,其中id为自增列,status默认值为0,可选值0,1
id自增, 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语句,通过回调函数拿到执行的结果
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基本操作方法有哪些的详细内容。
