mysql有兩種連接方式:一種是直接連接 另一種是池化連接,我們這篇講的是池化連接。
為了讓解惑,我簡答的寫份直接連接的程式碼,如下:
var mysql = require('mysql'); var connection = mysql.createConnection({ host : 'localhost', user : 'ac', password : '123456', database : 'textPro' }); connection.connect(); connection.query('SELECT * from1 userInfo', function (error, results, fields) { if (error) throw error; console.log('The solution is: ', results); }); connection.end();
createConnection和createPool的差別是: createPool(連結池)連線可以更合理的利用伺服器資料,減少資料浪費
安裝之後在db/index.js中開始編寫:
const mysql = require("mysql") //创建连接池 const db= mysql.createPool({ host : 'localhost', //连接主机 port : 3306, //端口号 database : 'test', //连接的是哪一个库 user : 'root', //用户名 password : '', //密码 connectionLimit : 50, //用于指定连接池中最大的链接数,默认属性值为10. //用于指定允许挂起的最大连接数,如果挂起的连接数超过该数值,就会立即抛出一个错误, //默认属性值为0.代表不允许被挂起的最大连接数。 queueLimit:3 })
建立了連接池之後,可以直接使用連接池物件的getConnection方法從連接池中取得一個連接,如果連接池中沒有可用連接,將隱含的建立一個資料庫連接。
const mysql = require("mysql") //创建连接池 const db= mysql.createPool({ host : 'localhost', //连接主机 port : 3306, //端口号 database : 'test', //连接的是哪一个库 user : 'root', //用户名 password : '', //密码 connectionLimit : 50, //用于指定连接池中最大的链接数,默认属性值为10. //用于指定允许挂起的最大连接数,如果挂起的连接数超过该数值,就会立即抛出一个错误, //默认属性值为0.代表不允许被挂起的最大连接数。 queueLimit:3 }) module.exports.query = (sql, values.callback) => { //err: 该参数是指操作失败时的错误对象。 //connection: 该值为一个对象,代表获取到的连接对象。当连接失败时,该值为undefined。 db.getConnection(function(err, connection) { if (err) { console.log('与mysql数据库建立连接失败'); pool.releaseConnection(); //释放链接 } else { console.log('与mysql数据库建立连接成功'); connection.query(sql,values,(err, res) => { if (err) { console.log('执行sql语句失败,查询数据失败'); //connection.release() 当一个连接不需要使用时,使用该方法将其归还到连接池中 release释放 connection.release(); callback(err,null) } else { console.log('执行sql语句成功'); callback(null,res) //pool.end() 当一个连接池不需要使用时,可以使用该方法关闭连接池 pool.end(); } }) } }) }
引入呼叫db模組
const query=require('./db').query; let sql='SELECT * FROM class WHERE class_id=? AND class_name=?' let userId=1; let userName='阿辰'; query(sql,[userId,userName],(err,res)=>{ if(err){ console.log('发生了错误***',err) return } console.log('找到了',res) })
const query=require('./db').query與const query=require('./db')區別
第一種寫法只取得了"./db"模組中的query函數,如果需要使用其他導出項,則需要再次取得。
第二種寫法取得了"./db"模組導出的所有項,不需要在程式碼中重複取得不同的導出項。
以上是node+mysql資料庫連線池連線的方法是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!