在Node.js中使用Mysql數(shù)據(jù)庫(二)連接和操作數(shù)據(jù)庫

首先推薦官方文檔
https://www.npmjs.com/package/mysql

連接mysql數(shù)據(jù)庫

從node庫中引用mysql后肋演,可以用createConnection()創(chuàng)建一個連接,需要將一些配置參數(shù)傳給函數(shù)

var mysql      = require('mysql');
var connection = mysql.createConnection({
  host     : 'localhost',
  user     : 'me',
  password : 'secret',
  database : 'my_db'
});

數(shù)據(jù)庫連接的建立與關(guān)閉

通過mysql.createConnection()后可以獲得一個mysql connection對象盏求,可以通過這個對象調(diào)用connect()或者end()來建立或關(guān)閉連接。

connection.connect();  // 連接建立
connection.end();      // 連接關(guān)閉

注意:由于在node中的網(wǎng)路請求是異步的,所以數(shù)據(jù)庫查詢操作也是異步的,通過一個任務(wù)隊列來依次執(zhí)行测垛,所以end()并不會直接關(guān)閉,而是將存在任務(wù)隊列中的任務(wù)都發(fā)送出去后再關(guān)閉秧均。

以下是官網(wǎng)原文

  • Every method you invoke on a connection is queued and executed in sequence.
  • Closing the connection is done using end() which makes sure all remaining queries are executed before sending a quit packet to the mysql server.

數(shù)據(jù)庫連接不關(guān)閉運行運行程序后程序是不會停止的食侮,要手動Ctrl+C才會停止
這是一個官網(wǎng)建議的連接實例

var mysql      = require('mysql');
var connection = mysql.createConnection({
  host     : 'example.org',
  user     : 'bob',
  password : 'secret'
});
 
connection.connect(function(err) {
  if (err) {
    console.error('error connecting: ' + err.stack);
    return;
  }
 
  console.log('connected as id ' + connection.threadId);
});

簡單的增刪改查CURD

我現(xiàn)在有一個表,表中只有兩個列

  1. id 自增主鍵
  2. name varchar類型
執(zhí)行sql語句的方法
  1. 直接將要執(zhí)行的sql語句放入
connection.query(`delete from test where id= 1`, (error, results) => {
    if (error) throw error;
    console.log(results);
});

2.用?替換sql執(zhí)行時需要更改的參數(shù)
將需要作為參數(shù)的部分用?代替目胡,在后面?zhèn)魅雲(yún)?shù)作為?依次順序?qū)?yīng)的值锯七,需要注意的是,?替換進去的字符串值會被默認(rèn)加上' '誉己,比如這個"測試問號"和2被替換進?后sql語句是這樣的update test set name = '測試問號' where id = 2

connection.query(`update test set name = ? where id = ?`, ["測試問號", 2], (error, results) => {
    if (error) throw error;
    console.log(results);
});

3.設(shè)置執(zhí)行參數(shù)
sql執(zhí)行時可以帶超時參數(shù)眉尸,替換?值參數(shù)

connection.query({
  sql: `update test set name = ? where id = ?`,
  timeout: 40000, // 40s
  values:  ["測試問號", 2]
}, function (error, results, fields) {
    if (error) throw error;
    console.log(results);
});
接著引用官方的連接實例來一個完整的增刪查改:
var mysql      = require('mysql');
var connection = mysql.createConnection({
  host     : 'example.org',
  user     : 'bob',
  password : 'secret'
});
 
connection.connect(function(err) {
  if (err) {
    console.error('error connecting: ' + err.stack);
    return;
  }
 
  console.log('connected as id ' + connection.threadId);
});
// 增
connection.query(`insert into test(name) values(?)`,"測試",(error, results) =>{
    if (error) throw error;
    console.log(results);
});

// 刪
connection.query(`delete from test where id= ?`,1,(error, results) =>{
    if (error) throw error;
    console.log(results);
});

// 查
connection.query('SELECT * from test', function (error, results, fields) {
    if (error) throw error;
    console.log("查詢結(jié)果是");
    console.log(results);
});

// 改

connection.query(`update test set name = "測試修改" where id = 2`,(error, results) =>{
    if (error) throw error;
    console.log(results);
});

// 關(guān)閉連接
connection.end();

運行結(jié)果:

connected as id 286718
OkPacket {
  fieldCount: 0,
  affectedRows: 1,
  insertId: 5,
  serverStatus: 2,
  warningCount: 0,
  message: '',
  protocol41: true,
  changedRows: 0 }
OkPacket {
  fieldCount: 0,
  affectedRows: 1,
  insertId: 0,
  serverStatus: 2,
  warningCount: 0,
  message: '',
  protocol41: true,
  changedRows: 0 }
查詢結(jié)果是
[ RowDataPacket { id: 2, name: 'change Hellow JabinGP again' },
  RowDataPacket { id: 3, name: '測試' },
  RowDataPacket { id: 4, name: '測試' },
  RowDataPacket { id: 5, name: '測試' } ]
OkPacket {
  fieldCount: 0,
  affectedRows: 1,
  insertId: 0,
  serverStatus: 2,
  warningCount: 0,
  message: '(Rows matched: 1  Changed: 1  Warnings: 0',
  protocol41: true,
  changedRows: 1 }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市巫延,隨后出現(xiàn)的幾起案子效五,更是在濱河造成了極大的恐慌,老刑警劉巖炉峰,帶你破解...
    沈念sama閱讀 217,734評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件畏妖,死亡現(xiàn)場離奇詭異,居然都是意外死亡疼阔,警方通過查閱死者的電腦和手機戒劫,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評論 3 394
  • 文/潘曉璐 我一進店門半夷,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人迅细,你說我怎么就攤上這事巫橄。” “怎么了茵典?”我有些...
    開封第一講書人閱讀 164,133評論 0 354
  • 文/不壞的土叔 我叫張陵湘换,是天一觀的道長。 經(jīng)常有香客問我统阿,道長彩倚,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,532評論 1 293
  • 正文 為了忘掉前任扶平,我火速辦了婚禮帆离,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘结澄。我一直安慰自己哥谷,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,585評論 6 392
  • 文/花漫 我一把揭開白布麻献。 她就那樣靜靜地躺著们妥,像睡著了一般。 火紅的嫁衣襯著肌膚如雪勉吻。 梳的紋絲不亂的頭發(fā)上王悍,一...
    開封第一講書人閱讀 51,462評論 1 302
  • 那天,我揣著相機與錄音餐曼,去河邊找鬼压储。 笑死,一個胖子當(dāng)著我的面吹牛源譬,可吹牛的內(nèi)容都是我干的集惋。 我是一名探鬼主播,決...
    沈念sama閱讀 40,262評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼踩娘,長吁一口氣:“原來是場噩夢啊……” “哼刮刑!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起养渴,我...
    開封第一講書人閱讀 39,153評論 0 276
  • 序言:老撾萬榮一對情侶失蹤雷绢,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后理卑,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體翘紊,經(jīng)...
    沈念sama閱讀 45,587評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,792評論 3 336
  • 正文 我和宋清朗相戀三年藐唠,在試婚紗的時候發(fā)現(xiàn)自己被綠了帆疟。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鹉究。...
    茶點故事閱讀 39,919評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖踪宠,靈堂內(nèi)的尸體忽然破棺而出自赔,到底是詐尸還是另有隱情,我是刑警寧澤柳琢,帶...
    沈念sama閱讀 35,635評論 5 345
  • 正文 年R本政府宣布绍妨,位于F島的核電站,受9級特大地震影響柬脸,放射性物質(zhì)發(fā)生泄漏痘绎。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,237評論 3 329
  • 文/蒙蒙 一肖粮、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧尔苦,春花似錦涩馆、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,855評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至稠项,卻和暖如春涯雅,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背展运。 一陣腳步聲響...
    開封第一講書人閱讀 32,983評論 1 269
  • 我被黑心中介騙來泰國打工活逆, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人拗胜。 一個月前我還...
    沈念sama閱讀 48,048評論 3 370
  • 正文 我出身青樓蔗候,卻偏偏與公主長得像,于是被迫代替她去往敵國和親埂软。 傳聞我的和親對象是個殘疾皇子锈遥,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,864評論 2 354