使用Node做Web开发,基本上都是使用NoSQL数据库,最频繁的就是使用MongoDB了,自己做了一些简单的Web开发,为了降低学习门槛,一直使用MySQL来做数据库。这里简单介绍一下连接MySQL数据库的方式,希望能帮助到其他人。
npm install --save mysql
使用上述命令安装完MySQL的模块后,就可以直接使用了,官网的DOCS里一个简单的例子如下就可以入门了。
var mysql = require('mysql');var connection = mysql.createConnection({ host: 'localhost', user: 'me', password : 'secret', database : 'my_db'});connection.connect();connection.query('SELECT 1 + 1 AS solution', function(err, rows, fields) { if (err) throw err; console.log('The solution is: ', rows[0].solution);});connection.end();
很简单的一个例子,从上面的例子可以得出:使用createConnection(option)方法创建一个连接对象,然后连接对象的connect()方法创建连接,最后使用query()方法执行SQL语句,返回结果作为回调函数的参数rows返回,rows为数组类型。
1. 连接
创建连接对象,需要传入连接数据库的一些连接参数,也就是createConnection(option)里的option,option是一个对象,以键值对的形式传入createConnection()方法里。上例列举出了最基本的参数:
host 主机名 user 连接数据库的用户 password 密码 database 数据库名称还有其他的参数,可以查询下官方DOCS,这里不一一列举了,初期学习上面这些参数就足以。
2. 关闭
关闭一个连接使用end()方法,end()方法提供一个回调函数,如下:
connect.end(function(err){ console.log('End a connection');});
这是建议使用的方法,end()方法会等待连接回调完成后才关闭连接。官方还提供了另外一种方法destroy()方法,这个方法直接关闭连接,不会等待回调完成。
举个简单的例子:
var mysql = require('mysql');var option = require('./connect.js').option;var conn = mysql.createConnection(option);conn.query('select * from message',function(err,rows,fields){ if(!err){ console.log(rows); }});conn.end(function(err){ console.log('end a connection');});
最终结果会是:先打印完SELECT数据表结果后,再打印end a connection。而如果你将关闭方法换成conn.destroy();,那么你就别想返回任何结果了,因为还没等回调结束就已经终止连接了。
3. 连接池
连接池的原理是一开始就给你创建多个连接对象放在一个“池子”里,用的时候取一个,用完了放回“池子”里,在一定程度上是有利于节省系统开销的,因为连接对象是在最开始的时候就创建好了,使用的时候不再需要系统开销去创建数据库连接对象。官方DOCS介绍了连接方法:
新闻热点
疑难解答
图片精选