Node连接MySql实战(增删改查)

一.Node连接Mysql

1.安装Mysql模块
npm install mysql
2.连接Mysql
const mysql = require('mysql');
    
    let connection = mysql.createConnection({
        host : 'localhost', // 连接的服务器ip
        user : 'root',  // 数据库用户名
        password : '123456', // MySQL的密码
        database : 'yirenck' //要连接的数据库名
    });

connection.connect(function(err) {
  if (err) {
    console.error('连接失败: ' + err.stack);
    return;
  }

  console.log('连接成功 id ' + connection.threadId);
});

二.Node操作Mysql(增删改查)

1.查询
connection.query('SELECT * FROM t_user WHERE username = "whg"', (err, results, fields) => {
    if(err){
        console.log("错误原因:",err);
    }
     console.log("成功返回数据:");
    console.log(results);
})
2.添加
connection.query('INSERT INTO t_user(username, pass) VALUES(?, ?)',['whg', '123'], (err, results) => {
   if(err){
        console.log("错误原因:",err);
    }
     console.log("成功返回数据:");
    console.log(results);
})
3.删除
connection.query('INSERT INTO t_user(username, pass) VALUES(?, ?)',['whg', '123'], (err, results) => {
   if(err){
        console.log("错误原因:",err);
    }
     console.log("成功返回数据:");
    console.log(results);
})
4.更新
onnection.query('UPDATE t_user SET pass = "321" WHERE username = "whg"', (err, results) => {
   if(err){
        console.log("错误原因:",err);
    }
     console.log("成功返回数据:");
    console.log(results);
})
5.结束连接
connection.end(function(err) {
  
});
 // connection.destroy(); 这两种都行,第二种是强制结束。
console.log("数据库已关闭")

了解完直接上代码封装

1.数据库配置文件,创建mysql.config.js
//配置链接数据库参数
module.exports = {
    host : 'localhost',
    port : 3306,//端口号
    database : 'yirenck',//数据库名
    user : 'root',//数据库用户名
    password : '123456'//数据库密码
};
2.封装、暴露方法
let mysql = require('mysql');//引入mysql模块
var databaseConfig = require('./mysql.config');  //引入数据库配置模块中的数据

//向外暴露方法
module.exports = {
    query : function(sql,params,callback){
        //每次使用的时候需要创建链接,数据操作完成之后要关闭连接
        var connection = mysql.createConnection(databaseConfig);        
        connection.connect(function(err){
            if(err){
                console.log('数据库链接失败');
                throw err;
            }
         //开始数据操作
         //传入三个参数,第一个参数sql语句,第二个参数sql语句中需要的数据,第三个参数回调函数
        connection.query( sql, params, function(err,results,fields ){
           if(err){
                console.log('数据操作失败');
                throw err;
            }
            //将查询出来的数据返回给回调函数
            callback && callback(results, fields);
            //results作为数据操作后的结果,fields作为数据库连接的一些字段
            //停止链接数据库,必须再查询语句后,要不然一调用这个方法,就直接停止链接,数据操作就会失败
             connection.end(function(err){
                  if(err){
                      console.log('关闭数据库连接失败!');
                      throw err;
                  }
              });
           });
       });
    }
};
3.演示实例
var db=require('../model/mysql.js');
// 查询实例
db.query('select * from t_user', [],function(result,fields){
    console.log('查询结果:');
    console.log(JSON.stringify(result));
});
//添加实例
var  addSql = 'INSERT INTO websites(username,password) VALUES(?,?)';
var  addSqlParams =['咕噜先森', '666'];
db.query(addSql,addSqlParams,function(result,fields){
    console.log('添加成功')
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一人创客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值