Nodejs 链接 Mariadb 实例

没有数据库的后台可能只是前端+网络而已,之前对Mariadb系统的学习一段时间,加之Nodejs以及express的使用,现将用一个小的实例将nodejs与关系型数据库---MariaDB关联起来,当然非关系型数据库---Mongodb之后会在一个稍微大点的项目中依次罗列出来.

该文章的主要目标在于: Nodejs与MaiarDB关联;

第一部分 配置 Mariadb

1.1 Mariadb 概述

对于Mariadb的历史与渊源在此不过多累述,可以理解为开源的/升级的/MySQL的孪生兄弟.
如需详细文档请点击Mariadb系列文章, 在此简要将配置罗列一下(以Mac为例子)

1. xcode-select --install 下载最新xcode
2. 配置并检测Homebrew;
3. 下载MariaDB: brew install mariadb
4. 启动数据库服务: mysql.server start
5. 连接数据库: mysql -u root -p

1.2 启动数据服务,链接数据库
BWF-huanghaowei:~ 51Code$ mysql.server start 
Starting MySQL
 SUCCESS! 
 
BWF-huanghaowei:~ 51Code$ mysql -uroot
Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 3
Server version: 10.1.19-MariaDB Homebrew

Copyright (c) 2000, 2016, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> 

第二部分 Nodejs相关配置

2.1 Nodejs相关配置

MariaDB官网提供关联库---mariasqlgithub地址

2.2 实例代码
2.2.1 下载 mariasql
Desktop $ mkdir Test
$ cd Test
#下载配置, 中间可能会提示很多信息,在此忽略
$ npm install mariasql
...
..
.
4 warnings generated.
  SOLINK_MODULE(target) Release/sqlclient.node
clang: warning: libstdc++ is deprecated; move to libc++ with a minimum deployment target of OS X 10.9
/Users/51testing/Desktop/Test/asf
└─┬ mariasql@0.2.6 
  ├── lru-cache@2.7.3 
  └── nan@2.5.0 


$ ls 
node_modules

2.2.2 编写index.js文件

[默认之前已经启动Mariadb服务]

测试数据与表格
//表格
CREATE TABLE `orders` (
  `order_id` int(11) NOT NULL AUTO_INCREMENT,
  `order_date` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
  `order_amount` float(6,2) DEFAULT NULL,
  `customer_id` int(11) DEFAULT NULL,
  PRIMARY KEY (`order_id`)
);

//插入数据
INSERT INTO `orders` VALUES (1,'2016-12-14 04:02:35',111.00,1),(2,'2016-11-11 14:22:22',222222.00,2),(3,'2016-11-11 15:33:33',1.00,1),(4,'2016-12-12 03:11:11',123456.00,3),(5,'2016-12-14 07:18:17',1234.00,5);

nodejs代码
//链接Mariasql
var Client = require('mariasql');

//配置相关信息
var c = new Client({
  host: '127.0.0.1',
  //用户名
  user: 'root',
  //密码默认为空
  password: '',
  //使用哪个数据库
  db: 'user_db'
});

c.query('SHOW DATABASES', function(err, rows) {
  if (err)
    throw err;
    console.log('---------查看所有的数据库------------');
    console.dir(rows);
});


//使用array的形式快于对象,效果一样
c.query('SHOW TABLES', null, { useArray: true }, function(err, rows) {
  if (err)
    throw err;
  console.log('--------查看所有的数据表格-------------');
  console.dir(rows);
});

//结合使用SQL语句
c.query('SELECT * FROM orders', function(err, rows) {
  if (err)
    throw err;
  console.log('--------查看orders的数据-------------');
  console.dir(rows);
});

//使用占位符
c.query('SELECT * FROM orders WHERE order_id = ? AND customer_id = ?',
        [ 5, 5 ],
        function(err, rows) {
  if (err)
    throw err;
  console.log('--------SELECT + WHERE-------------');   
  console.dir(rows);
});

//定义sql语句, 稍后使用,另外一种占位符
var prep = c.prepare('SELECT * FROM orders WHERE order_id = :orderid AND customer_id = :customerid');
c.query(prep({orderid: 5, customerid: 5}), function(err, rows){
    if (err) {
        throw err
    } else {
         console.log('--------SELECT + WHERE-------------');    
        console.dir(rows);
    }
})


//关闭数据库
c.end();

打开终端,切换至该目录下, 执行$ node index即可.

更多设置请前往mariasql

在此只是简单介绍基本链接与使用,如果有兴趣可多参阅一些SQL注入相关知识与内容

更多精彩内容请关注“IT实战联盟”哦~~~


IT实战联盟.jpg
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容