上一篇文章只写了一丢丢,这篇才是正片,look look look
一、使用mysql模块操作数据库
1、查询数据
这里连接数据库的用户和密码都是我们在安装mysql时配置的密码。每个人的users表格里面数据不同,结果也会不一样哟!
// 导入mysql模块
const mysql=require('mysql')
// 2、建立与MySQL数据库的连接
const db=mysql.createPool({
// 数据库的IP地址
host:'127.0.0.1',
// 登录数据库的账号
user:'root',
// 登录db的密码
password:'admin123',
// 指定要操作哪个数据库
database:'my_db_01'
})
// 1-查询数据
const sqlStr='select * from users'
db.query(sqlStr,(err,result)=>{
// 查询失败
if(err) return console.log(err.message);
// 查询成功
console.log(result);
})
2、插入数据
巧2小黑板啦!这里有两个知识点:
1、可以通过英文?符号占位符指定具体的值
2、用insert into插入数据的话,我们可以通过affectRows来判断是否操作成功
// 要插入表中的数据
const user={uname:'thr', password:'thr123'}
// 待执行的SQL语句,其中问好表示占位符,是英文状态下
const sqlStr='insert into users (uname,password) values (?,?)'
// 执行SQL语句
db.query(sqlStr,[user.uname,user.password],(err,results)=>{
if(err) return console.log(err.message);
// 插入成功,如果执行的insert itno语句,则result是一个对象
// 可以通过affectRows属性来判断是否插入数据成功
if(results.affectedRows===1){
console.log('数据插入成功');
}
})
如果你删除过记录,你的id不一定是连续的,就比方说我这可能是5、6....
2.1插入数据的便捷方式
const user={uname:'test',password:'t001'}
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('数据插入成功');
}
})