Connector/Node.js 8是一个官方的node.js连接mysql的驱动,用于MySQL 5.7.12+ 以上数据库。在NodeJS开发中我们经常涉及到操作数据库,尤其是 MySQL,这是nodejs mysql 连接池。Nodejs要连接MySQL,可以使用Nodejs的MysQL驱动来实现。

MySQL 8.0 正式版发布,官方表示 MySQL 8 要比 MySQL 5.7 快 2 倍,还带来了大量的改进和更快的性能!

注意:从 MySQL 5.7 升级到 MySQL 8.0 仅支持通过使用 in-place 方式进行升级,并且不支持从 MySQL 8.0 降级到 MySQL 5.7(或从某个 MySQL 8.0 版本降级到任意一个更早的 MySQL 8.0 版本)。唯一受支持的替代方案是在升级之前对数据进行备份。

MySQL 8.0 for Linux 官方正式版 下载地址

mysql connector node.js(mysql的nodejsl链接驱动) v8.0.17 官方免费版

Node.js中JavaScript操作MySQL方法

一、建立数据库连接:createConnection(Object)方法

该方法接受一个对象作为参数,该对象有四个常用的属性host,user,password,database。与php中链接数据库的参数相同。属性列表如下:

host: 连接数据库所在的主机名. (默认: localhost)

port: 连接端口. (默认: 3306)

localAddress: 用于TCP连接的IP地址. (可选)

socketPath: 链接到unix域的路径。在使用host和port时该参数会被忽略.

user: MySQL用户的用户名.

password: MySQL用户的密码.

database: 链接到的数据库名称 (可选).

charset: 连接的字符集. (默认: 'UTF8_GENERAL_CI'.设置该值要使用大写!)

timezone: 储存本地时间的时区. (默认: 'local')

stringifyObjects: 是否序列化对象. See issue #501. (默认: 'false')

insecureAuth: 是否允许旧的身份验证方法连接到数据库实例. (默认: false)

typeCast: 确定是否讲column值转换为本地JavaScript类型列值. (默认: true)

queryFormat: 自定义的查询语句格式化函数.

supportBigNumbers: 数据库处理大数字(长整型和含小数),时应该启用 (默认: false).

bigNumberStrings: 启用 supportBigNumbers和bigNumberStrings 并强制这些数字以字符串的方式返回(默认: false).

dateStrings: 强制日期类型(TIMESTAMP, DATETIME, DATE)以字符串返回,而不是一javascript Date对象返回. (默认: false)

debug: 是否开启调试. (默认: false)

multipleStatements: 是否允许在一个query中传递多个查询语句. (Default: false)

flags: 链接标志.

还可以使用字符串连接数据库例如:

复制代码 代码如下:

var connection = mysql.createConnection('mysql://user:pass@host/db?debug=true&charset=BIG5_CHINESE_CI&timezone=-0700');

二、结束数据库连接end()和destroy()

end()接受一个回调函数,并且会在query结束之后才触发,如果query出错,仍然会终止链接,错误会传递到回调函数中处理。

destroy()立即终止数据库连接,即使还有query没有完成,之后的回调函数也不会在触发。

三、创建连接池 createPool(Object)

Object和createConnection参数相同。

可以监听connection事件,并设置session值

pool.on('connection', function(connection) {

connection.query('SET SESSION auto_increment_increment=1')

});

connection.release()释放链接到连接池。如果需要关闭连接并且删除,需要使用connection.destroy()

pool除了接受和connection相同的参数外,还接受几个扩展的参数

createConnection: 用于创建链接的函数. (Default: mysql.createConnection)

waitForConnections: 决定当没有连接池或者链接数打到最大值时pool的行为. 为true时链接会被放入队列中在可用是调用,为false时会立即返回error. (Default: true)

connectionLimit: 最大连接数. (Default: 10)

queueLimit: 连接池中连接请求的烈的最大长度,超过这个长度就会报错,值为0时没有限制. (Default: 0)

下载地址

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。