近期对node下的几个mysql操作库做了一下简单的调研
主要是针对这3个module进行
libmysqlclient,mysql-native, mysql
node-libmysqlclient
https://github.com/Sannis/node-mysql-libmysqlclient
基于libmysql的封装, 支持阻塞与非阻塞两种操作方式,目前在query部分功能比较完善,prepare statement方面还是有些bug,实际测试中一直出core
安装
npm install mysql-libmysqlclient
node-mysql
https://github.com/felixge/node-mysql
纯node的实现, 支持prepare statement, 数据的获取支持事件与callback两种方式
安装
npm install mysql
node-mysql-native
https://github.com/sidorares/nodejs-mysql-native
纯node的实现, 内置有简单的连接池支持,支持prepare statement, 数据的获取只支持通过事件方式
安装
npm install mysql-native
测试设计
测试表结构
CREATE TABLE `test10` (
`id` int(10) unsigned NOT NULL DEFAULT '0',
`txt` varchar(500) DEFAULT ''
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
测试数据
分别生成了含10, 100, 500, 1500行记录的4张表
使用10个并发连接分别对其进行SELECT * FROM table的查询
测试结论
其中数值表示qps值
在结果集较小时node-mysql-native明显胜出
当结果集增大到接近100行时,node-libmysqlclient开始表现出更佳的性能
node-mysql性能与其他两个module差距比较大,如果对性能有一定要求的话,则其基本不可用
测试代码
http://code.google.com/p/cnodejs/source/browse/#svn%2Ftrunk%2Fmysql-benchmark
/*查询数据*/
client.query(sql).addListener('row',function(results){
console.dir(results);
/*HTTP返回*/
response.writeHead(200,{'Content-Tyep':'text/plain'});
var data = JSON.stringify(results);
response.write(data + "\n");
response.end();
}).addListener('end', function() {
/*连接关闭*/
client.close();
});
我用mysql-native查询mysql,console.dir(results)方法可以将我需要的查询结果输出在服务端,但是通过response.write(data + “\n”)输出在我访问的页面里的却是第一条数据。 请问用何方法才能在我访问的页面中获得我想要的查询结果呢?求助中