Node.js中調(diào)用mysql存儲過程示例
例子僅在windows下測試通過,沒有放在linux下測試。如有問題,可以電郵給我~
1、安裝node.js、mysql,此處略(自行搜索吧)…;
2、創(chuàng)建一個名為test的數(shù)據(jù)庫,然后建一張名為user_info的表(僅供測試)…
這里假定mysql使用的用戶名為root,密碼為123456
相應的mysql如下:
/**
* 創(chuàng)建名為test的數(shù)據(jù)庫
*/
DROP DATABASE IF EXISTS test;
CREATE DATABASE test;
USE test;
/**
* 創(chuàng)建user_info表
*/
DROP TABLE IF EXISTS `user_info`;
CREATE TABLE `user_info` (
`userId` int(10) NOT NULL AUTO_INCREMENT,
`userName` varchar(20) DEFAULT NULL,
PRIMARY KEY (`userId`)
) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8;
/**
* 插入三條記錄
*/
INSERT INTO user_info VALUES (NULL, '張一'), (NULL, '張二'), (NULL, '張三');
3、創(chuàng)建存儲過程(寫的很冗余,故意的… 正好學習一下語法>_<);
DELIMITER $$
DROP PROCEDURE IF EXISTS `test`.`proc_simple`$$
CREATE PROCEDURE proc_simple(IN uid INT(10), OUT uName VARCHAR(2), OUT totalCount INT)
BEGIN
DECLARE str_name VARCHAR(20);
SET @str_name = '';
SET totalCount = 0;
SELECT COUNT(1),userName INTO totalCount,@str_name FROM user_info WHERE userId = uid;
SET uName = @str_name;
SELECT uName, totalCount;
END$$
DELIMITER ;
4、寫程序進行調(diào)用(假定存為名為sql.js的文件);
/**
* Created with JetBrains WebStorm.
* User: Meteoric_cry
* Date: 12-12-28
* Time: 上午00:18
* To change this template use File | Settings | File Templates.
*/
var mysql = require('mysql');
var connection = mysql.createConnection({
host : 'localhost',
port : 3306,
user : 'root',
password : '123456',
database : 'test',
charset : 'UTF8_GENERAL_CI',
debug : false
});
connection.connect();
connection.query('CALL proc_simple(1, @a, @b);', function(err, rows, fields) {
if (err) {
throw err;
}
var results = rows[0];
var row = results[0];
console.log("userName:",row.uName, " count:", row.totalCount);
});
connection.end();
5、運行示例程序;
- nodejs基于mssql模塊連接sqlserver數(shù)據(jù)庫的簡單封裝操作示例
- nodejs中操作mysql數(shù)據(jù)庫示例
- 初步使用Node連接Mysql數(shù)據(jù)庫
- 淺析node連接數(shù)據(jù)庫(express+mysql)
- nodejs集成sqlite使用示例
- Node.js的Koa框架上手及MySQL操作指南
- Node.js操作mysql數(shù)據(jù)庫增刪改查
- Node.js連接postgreSQL并進行數(shù)據(jù)操作
- NodeJS與Mysql的交互示例代碼
- node.js操作mysql(增刪改查)
- Node.js連接Sql Server 2008及數(shù)據(jù)層封裝詳解
相關(guān)文章
Node.js Sequelize如何實現(xiàn)數(shù)據(jù)庫的讀寫分離
Sequelize是一個易于使用,支持多SQL方言(dialect)的對象-關(guān)系映射框架(ORM),這個庫完全采用JavaScript開發(fā)并且能夠用在Node.JS環(huán)境中。它當前支持MySQL, MariaDB, SQLite 和 PostgreSQL 數(shù)據(jù)庫。在Node.js中,使用 Sequelize操作數(shù)據(jù)庫時,同樣支持讀寫分離。2016-10-10node?puppeteer爬蟲爬取電影網(wǎng)站及生成pdf文檔示例
這篇文章主要介紹了node?puppeteer爬蟲爬取電影網(wǎng)站及生成pdf文檔使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-07-07node.js同步/異步文件讀寫-fs,Stream文件流操作實例詳解
這篇文章主要介紹了node.js同步/異步文件讀寫-fs,Stream文件流操作,結(jié)合實例形式詳細分析了node.js針對文件的同步/異步讀寫與文件流相關(guān)操作技巧,需要的朋友可以參考下2023-06-06Node.js中使用計時器定時執(zhí)行函數(shù)詳解
這篇文章主要介紹了Node.js中使用計時器定時執(zhí)行函數(shù)詳解,本文使用了Node.js中的setTimeout和setInterval函數(shù),需要的朋友可以參考下2014-08-08