MySQL基础1——Express与MySQL联调.md

2024-05-05 16:38

本文主要是介绍MySQL基础1——Express与MySQL联调.md,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

0.目标

实现通过Node.js对MySQL进行数据CURD操作,这里将使用Node.js的Express框架。


1.前置条件

1.1 已经安装了MySQL数据库。

建议再安装一个可视化操作工具:MySQL Front

1.2 安装Express和MySQL

npm install express --save
npm install mysql --save

2.重点

2.0 文件夹结构预览

整个应用的流程如下:
这里写图片描述
启动app.js后,用户在浏览器发出请求,调用routes对应的方法,从models中找到处理方法,从config获取配置后对数据库进行操作。

2.1 定义数据库配置参数

这里先在config文件夹里创建一个db.js文件,导出一个名为onelib的数据库链接配置。

module.exports = {onelib: {host: '127.0.0.1',      // MySQL所在服务器IPuser: 'root',           // 用户名password: '',           // 密码database:'onelib',      // 数据库名称port: 3306,             // 端口号dateStrings: true,      // 时间以字符串形式显示,否则会有类似这样的显示:Thu Apr 14 2016 00:00:00 GMT+0800 (中国标准时间) 17:20:12}
};

注意,如果有多个数据库,可以增加一个配置参数,和onelib并列。如:

module.exports = {onelib: {……},newdb: {    // 新的数据库配置……}
};

2.2 设置数据库连接

仍然在config文件夹中创建一个文件,名为mysql.js。该文件用于建立与MySQL的连接。

var mysql = require('mysql');   // 引用mysql模块。注意要先安装mysql: npm install mysql
var config = require('./db');var onelib_pool = mysql.createPool(config.onelib);
exports.onelib_pool = onelib_pool;

注意,如果有多个数据库,只需要使用对应的配置(在db.js中定义的)信息即可设置多个数据库连接,如:

var mysql = require('mysql');   // 引用mysql模块。注意要先安装mysql: npm install mysql
var config = require('./db');// 数据库连接
var onelib_pool = mysql.createPool(config.onelib);
exports.onelib_pool = onelib_pool;// 新的数据库连接
var newdb_pool = mysql.createPool(config. newdb);
exports. newdb_pool = newdb_pool;

2.3 操作数据库的模型

在数据库配置完毕并建立连接后,即可对数据库进行CURD操作。
我们在models文件夹中,创建一个名为tasks.js的文件,用来存储对task模块的操作:

var mysql = require('../config/mysql');// 获取数据库连接配置var Task = function() {};   // 预定义一个空的类,接下来只需要往里增加方法即可Task.prototype.find = function(id, callback) {   // 增加一个方法,名为find,传入参数为id和回调函数callback// sql查询语句,注意这里的“?”号,它会在query的时候被处理var sql = "SELECT * FROM tasks WHERE id =?";// 获取mysql的onelib_pool连接池,以回调的方式处理(即获取成功后,执行下一步)mysql.onelib_pool.getConnection(function(err, connection) {if (err) {callback(true);return;}// 获取成功后,执行query// 注意到这里有三个参数,第一个是sql语句,第二个是一个数组,第三个是回调函数// 需要着重说明的是第二个参数,它将依次替换sql里的“?”号// sql语句被替换后,会是这样的:"SELECT * FROM tasks WHERE id = " + idconnection.query(sql, [id], function(err, results) {if (err) {callback(true);return;}callback(false, results);});});
};

Hint1:如果我们要对newdb进行操作,则可以这样写:

Task.prototype.find = function(id, callback){……mysql.newdb_pool.getConnection(function(err, connection) {……});
};

Hint2:关于sql语句的填写:

如果有多个参数要传入,可以这么写:

var sql = "SELECT * FROM tasks WHERE releaser=? OR relative=?";
var sql_value_arr = [name, name];   // 对应sql语句里的问号
……
connection.query(sql, sql_value_arr, function(err, results) {……    
}

如果没有参数要传入,可以这么写:

var sql = "SELECT * FROM tasks";
var sql_value_arr = [];
……
connection.query(sql, sql_value_arr, function(err, results) {……    
}

2.4 处理路由请求

在routes文件夹中创建一个文件:tasks.js。这个文件用来处理用户的路由请求

// 引用tasks模型
var Task = require('../models/tasks');// 根据taskid获取任务数据
exports.getTask = function(req, res) {var taskid = req.params.taskid;var task = new Task();task.find(taskid,function(err,result){if(err){res.send('没有找到taskid为'+taskid+'的任务');}else if(undefined!=result){ // 增加这个判断,否则在没有查询到的情况下,Node.js会挂掉res.send(result.length === 1 ? result[0]:result);}else{res.end("Error");}});
}

Hint1:关于查询结果的结构
查询结果如果只有一个,会以对象的形式返回。查询结果如果有多个,会以数组的形式把对象组合起来

Hint2:关于undefined的检查
如果查询结果result为undefined,而我们又对result取result[0],将导致出错,Node.js会直接挂掉!

Hint3:对结果集进行解析
当前的代码会将查询结果直接以对象的形式输出到页面中,如果不是ajax的请求,这样的输出会unreadable;所以,我们有必要在输出之前先对其进行“装饰”。虽然这个是前端工程师的工作,但我们的目标是全栈工程师嘛。

2.5 映射路由到应用中

注意到,我们之前写的方法全部是export的,即可以被外部调用的。我们把路由请求的处理也export了,目的是让app.js文件更简洁,路由的实现全部在routes文件夹里,而不会掺杂在app.js文件中。

下面给出app.js代码

var express = require('express'), path = require('path'), task = require('./routes/tasks');
var app = express();/* 主页 */
app.get('/', function(req, res){res.sendfile('views/index.html');
});/* 处理路由请求 */
// Onelib
app.get('/gettask/:taskid',task.getTask);
// newdb
app.get('/gettask/:taskid',task.getTask);/* 设置静态文件路径 */
app.use(express.static(path.join(__dirname, 'public')));/* 启动服务器 */
var server = app.listen(3000, function(){var host = server.address().address;var port = server.address().port;console.log("*** OneLib智库已启动,访问地址为 http://%s:%s", host, port)
});

打开浏览器,输入

http://127.0.0.1:3000/gettask/1

taskid为1的数据将显示在网页中(当然,你的数据库里首先要有这个数据 ^ _ ^)


 **原创文章,未经许可,请勿转载**作者:林晓州日期:2016.05.17QQ:1139904786Blog:http://blog.csdn.net/kkdestiny参考文档:http://www.tuicool.com/articles/UZzeyuy

这篇关于MySQL基础1——Express与MySQL联调.md的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/962155

相关文章

SQL中的外键约束

外键约束用于表示两张表中的指标连接关系。外键约束的作用主要有以下三点: 1.确保子表中的某个字段(外键)只能引用父表中的有效记录2.主表中的列被删除时,子表中的关联列也会被删除3.主表中的列更新时,子表中的关联元素也会被更新 子表中的元素指向主表 以下是一个外键约束的实例展示

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

如何去写一手好SQL

MySQL性能 最大数据量 抛开数据量和并发数,谈性能都是耍流氓。MySQL没有限制单表最大记录数,它取决于操作系统对文件大小的限制。 《阿里巴巴Java开发手册》提出单表行数超过500万行或者单表容量超过2GB,才推荐分库分表。性能由综合因素决定,抛开业务复杂度,影响程度依次是硬件配置、MySQL配置、数据表设计、索引优化。500万这个值仅供参考,并非铁律。 博主曾经操作过超过4亿行数据

性能分析之MySQL索引实战案例

文章目录 一、前言二、准备三、MySQL索引优化四、MySQL 索引知识回顾五、总结 一、前言 在上一讲性能工具之 JProfiler 简单登录案例分析实战中已经发现SQL没有建立索引问题,本文将一起从代码层去分析为什么没有建立索引? 开源ERP项目地址:https://gitee.com/jishenghua/JSH_ERP 二、准备 打开IDEA找到登录请求资源路径位置

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

MySQL高性能优化规范

前言:      笔者最近上班途中突然想丰富下自己的数据库优化技能。于是在查阅了多篇文章后,总结出了这篇! 数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,并且最后不要超过32个字符 临时库表必须以tmp_为前缀并以日期为后缀,备份

[MySQL表的增删改查-进阶]

🌈个人主页:努力学编程’ ⛅个人推荐: c语言从初阶到进阶 JavaEE详解 数据结构 ⚡学好数据结构,刷题刻不容缓:点击一起刷题 🌙心灵鸡汤:总有人要赢,为什么不能是我呢 💻💻💻数据库约束 🔭🔭🔭约束类型 not null: 指示某列不能存储 NULL 值unique: 保证某列的每行必须有唯一的值default: 规定没有给列赋值时的默认值.primary key:

MySQL-CRUD入门1

文章目录 认识配置文件client节点mysql节点mysqld节点 数据的添加(Create)添加一行数据添加多行数据两种添加数据的效率对比 数据的查询(Retrieve)全列查询指定列查询查询中带有表达式关于字面量关于as重命名 临时表引入distinct去重order by 排序关于NULL 认识配置文件 在我们的MySQL服务安装好了之后, 会有一个配置文件, 也就

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念