关于node.js与MySQL的交互,网上的技术文章五花八门真正能解决问题的寥寥无几。看了AndyLizh的一篇博文,仔细研读,加上自己的见解希望对新手有帮助。
首先了解下数据库链接选项(Connection Options),在下面的代码块中会用到,可以根据自己的需求添加。
host:主机地址 (默认:localhost)
user:用户名
password:密码
port:端口号 (默认:3306)
database:数据库名
charset:连接字符集(默认:’UTF8_GENERAL_CI’,注意字符集的字母都要大写)
localAddress:此IP用于TCP连接(可选)
socketPath:连接到unix域路径,当使用 host 和 port 时会被忽略
timezone:时区(默认:’local’)
connectTimeout:连接超时(默认:不限制;单位:毫秒)
stringifyObjects:是否序列化对象(默认:’false’ ;与安全相关https://github.com/felixge/node-mysql/issues/501)
typeCast:是否将列值转化为本地JavaScript类型值 (默认:true)
queryFormat:自定义query语句格式化方法 https://github.com/felixge/node-mysql#custom-format
supportBigNumbers:数据库支持bigint或decimal类型列时,需要设此option为true (默认:false)
bigNumberStrings:supportBigNumbers和bigNumberStrings启用 强制bigint或decimal列以JavaScript字符串类型返回(默认:false)
dateStrings:强制timestamp,datetime,data类型以字符串类型返回,而不是JavaScript Date类型(默认:false)
debug:开启调试(默认:false)
multipleStatements:是否许一个query中有多个MySQL语句 (默认:false)
flags:用于修改连接标志,更多详情:https://github.com/felixge/node-mysql#connection-flags
ssl:使用ssl参数(与crypto.createCredenitals参数格式一至)或一个包含ssl配置文件名称的字符串,目前只捆绑Amazon RDS的配置文件
第一种方法:
先上代码:
var mysql = require('mysql'); //调用MySQL模块
var co = require('co');
//测试输出代码
co(function*() {
//var sql = 'INSERT INTO accountinformation(account,passWord) VALUES(?,?)';
//var sql_Params = ['Wilson', 'abcd'];
//var res=ccInsert(sql,sql_Params);
//var sql='SELECT account from accountinformation where account=\'Wilson\'';
//var sql='delete from accountinformation where account=\'Wilson\'';
console.log(sql);
var res=coQuery(sql);
var result = yield res;
if(result.code==1){
console.log("success");
} else{
console.log("error");
}
});
function coQuery (sql){//查询,删除
return function(callback) {
Query(sql,callback);
};
}
function ccInsert (sql,sql_Params){//添加,更新
return function(callback) {
Insert(sql,sql_Params,callback);
};
}
function Query(sql,callback){
console.log("connect start");
//创建一个connection连接
var connection = mysql.createConnection({
host : 'localhost', //主机
user : 'root', //MySQL认证用户名
password : '123456', //MySQL认证用户密码
port: '3306', //端口号
database:'lean' //端口号
});
//连接数据
connection.connect(function(err){
if(err){
var str={//链接失败报错信息
code:0,
message: err.message
};
callback(null,str);
return;
}
});
connection.query(sql, function(err, rows) {
if (err) {
console.log(err);
var str={//查询失败报错信息
code:0,
message: err
};
callback(null,str);
connection.end();
console.log("connect end1");
return;
}
else{
var str={//查询成功
code:1,
message: rows
};
callback(null,str);
connection.end();
console.log("connect end2");
return ;
}
});
};
function Insert(sql,sql_Params,callback){
console.log("connect start");
//创建一个connection连接
var connection = mysql.createConnection({
host : 'localhost', //主机
user : 'root', //MySQL认证用户名
password : '123456', //MySQL认证用户密码
port: '3306', //端口号
database:'lean'
});
//连接数据
connection.connect(function(err){
if(err){
var str={//链接失败报错信息
code:0,
message: err
};
callback(null,str);
return;
}
});
connection.query(sql,sql_Params, function(err,rows) {
if (err) {
var str={//查询失败报错信息
code:0,
message: err
};
callback(null,str);
connection.end();
return;
}
else{
var str={
code:1,
message: rows.affectedRows
};
callback(null,str);
connection.end(); //关闭数据库连接,结束
console.log(str);
return ;
}
});
console.log("connect end");
};
添加返回的参数列表,可以根据需要加到json中:
OkPacket {
fieldCount: 0,
affectedRows: 1,
insertId: 92,
serverStatus: 2,
warningCount: 0,
message: '',
protocol41: true,
changedRows: 0 }
查询返回的参数列表:
[ RowDataPacket { account: 'Wilson' } ]
第二种方法:
先上代码:
var mysql = require('mysql'); //调用MySQL模块
var co = require('co');
//创建一个connection
var pool = mysql.createPool({
host : 'localhost', //主机
user : 'root', //MySQL认证用户名
password : '123456', //MySQL认证用户密码
port: '3306' //端口号
});
co(function*() {
console.log("start");
var msg=coQuery('SELECT 1 + 1 AS solution');
var result = yield msg;
console.log("solution:"+result.data[0].solution);
});
function coQuery (sql){
return function(callback) {
connect(sql,callback);
};
}
function connect(sql,callback){
pool.getConnection(function(err, connection) {
connection.query({sql,function (field, next) {
if (field.type == 'VAR_STRING' || field.type == 'BLOB') {
}
return next();
}},function(err, rows) {
if (err) {
connection.rollback(function() {
var str={
code:0,
message: err.message
};
callback(null,str);
connection.release();
return ;
});
}else{
var str="";
if(rows!==undefined){
if(rows.length > 0) {
str={
code:0,
message: "success",
data:rows
};
}else{
str={
code:1,
message:"no result"
};
}
}else{
str={
code:0,
message: "success",
data:rows
};
}
callback(null,str);
connection.release();
return ;
}
}
);
});
}