1.node端操做数据库
其中mysql中的connect配置须要换成本身的node
链接数据库 var mysql = require('mysql') //调用MySQL模块 mysql模块要安装 $ npm install mysql //建立一个connection var connection = mysql.createConnection({ host: '', //主机 user: 'root', //MySQL认证用户名 password: 'password', //MySQL认证用户密码 port: '3306', //端口号 database: '' //数据库名 }) //建立一个connection connection.connect(function (err) { if (err) { console.log('[query] - :' + err) return } console.log('[connection connect] succeed!') }) /** * 如下以info_user表为例 */ //执行SQL语句---查询 connection.query('SELECT * FROM info_user WHERE user_name = "project_admin_2"', function (err, results, fields) { if (err) { console.log('[SELECT] - :' + err) return } console.log('The solution is: ', results) }) //执行SQL语句---添加 connection.query('INSERT INTO info_user(user_name, project_id, role_flag, graph_info) VALUES(?, ?, ?, ?)',['jiushugao', '1', '1','{}'], (err, results) => { if(err){ console.log('[INSERT] - :' + err) } console.log(results) }) //执行SQL语句---删除 connection.query('DELETE FROM info_user WHERE user_name = "jiushugao"', (err, results) => { if(err){ console.log('[DELETE] - :' + err) } console.log(results) }) //执行SQL语句---更新 connection.query('UPDATE info_user SET role_flag = "2" WHERE user_name = "jiushugao"', (err, results) => { if(err){ console.log('[UPDATE] - :' + err) } console.log(results) }) //关闭connection connection.end(function (err) { if (err) { return; } console.log('[connection end] succeed!') }) 能够将他们封装起来使用效果更佳,下面分三个文件
mysql.config.jsmysql
// 配置连接数据库参数 // 数据库参数用本身的 module.exports = { host : 'localhost', //ip地址,本地默认localhost port : 3306,//端口号 database : '',//数据库名 user : 'root',//数据库用户名 password : 'password'//数据库密码 }
mysqlOperation.jssql
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 } }) }) }) } }
完成上述配置以后就能够执行了数据库
demo.jsnpm
var db = require('../mysql/mysqlOperation') // 查询实例 var selectSql = 'SELECT * FROM info_user WHERE user_name = "project_admin_2"' db.query(selectSql, [], function (result, fields) { console.log('查询结果:') console.log(result) }) //添加实例 var addSql = 'INSERT INTO info_user(user_name, project_id, role_flag, graph_info) VALUES(?, ?, ?, ?)' var addSqlParams = ['jiushugao', '1', '1', '{}'] db.query(addSql, addSqlParams, function (result, fields) { console.log('添加成功') })