资讯专栏INFORMATION COLUMN

Node.js项目中操作MySQL

derek_334892 / 2992人阅读

摘要:初始化项目创建项目目录,并使用初始化项目后,执行下面操作安装依赖创建填写你的填写你的用户名填写你的密码在中执行,当看到中打印出,表明数据库连接成功。打开浏览器访问,当看到屏幕显示时,表名项目初始化成功。

本文是一篇使用mysql这个npm模块操作MySQL数据库的基础教程。 不涉及MySQL的安装和配置,如果电脑中还未安装MySQL, 推荐安装WAMP、XAMPP等集成环境。本文中还使用到了轻量级的Node.js框架Koa搭建web程序,为的是通过前端浏览器请求的方式来模拟项目场景,你无需掌握Koa框架的语法也是可以轻松阅读本文的。

初始化项目

创建项目目录,并使用npm init初始化项目后,执行下面操作:

安装依赖

</>复制代码

  1. npm install mysql koa koa-router
创建index.js

</>复制代码

  1. // index.js
  2. const Koa = require("koa");
  3. const Router = require("koa-router");
  4. const mysql = require("mysql");
  5. const app = new Koa();
  6. const router = new Router();
  7. const connection = mysql.createConnection({
  8. host: "localhost", // 填写你的mysql host
  9. user: "root", // 填写你的mysql用户名
  10. password: "123456" // 填写你的mysql密码
  11. })
  12. connection.connect(err => {
  13. if(err) throw err;
  14. console.log("mysql connncted success!");
  15. })
  16. router.get("/", ctx => {
  17. ctx.body = "Visit index";
  18. })
  19. app.use(router.routes());
  20. app.listen(3000);

在shell中执行node index.js,当看到shell中打印出mysql connected success!,表明MySQL数据库连接成功。

打开浏览器, 访问localhost:3000,当看到屏幕显示Visit index时,表名项目初始化成功。

数据库操作 创建数据库

当访问/createdb时,创建一个mysqlkoa的数据库,代码如下:

</>复制代码

  1. router.get("/createdb", ctx => {
  2. return new Promise(resolve => {
  3. const sql = `CREATE DATABASE mysqlkoa`;
  4. connection.query(sql, (err) => {
  5. if (err) throw err;
  6. ctx.body = {
  7. code: 200,
  8. msg: `create database mysqlkoa success!`
  9. }
  10. resolve();
  11. });
  12. })
  13. })

重新执行node index.js,并使用浏览器访问localhost:3000/createdb

创建数据表

为了方便,我们直接在连接时使用刚才创建的数据库,需要在mysql.createConnection中添加database:mysqlkoa的配置项。

</>复制代码

  1. const connection = mysql.createConnection({
  2. host: "localhost",
  3. user: "root",
  4. password: "123456",
  5. database: "mysqlkoa" // 添加该列
  6. })

当访问/createtable时,我们创建一个数据表fe_frame,该表用来保存前端框架的数据:

</>复制代码

  1. router.get("/createtable", ctx => {
  2. return new Promise(resolve => {
  3. const sql = `CREATE TABLE fe_frame(
  4. id INT(11) AUTO_INCREMENT PRIMARY KEY,
  5. name VARCHAR(255),
  6. author VARCHAR(255)
  7. )`;
  8. connection.query(sql, (err ,results, filelds) => {
  9. if (err) throw err;
  10. ctx.body = {
  11. code: 200,
  12. msg: `create table of fe_frame success!`
  13. }
  14. resolve();
  15. })
  16. })
  17. })

重新执行node index.js,并使用浏览器访问localhost:3000/createtable

插入数据
插入单条数据

当访问/insert时,用来插入单条数据:

</>复制代码

  1. router.get("/insert", ctx => {
  2. return new Promise(resolve => {
  3. const sql = `INSERT INTO fe_frame(name, author)
  4. VALUES("vue", "Evan")`;
  5. connection.query(sql, (err) => {
  6. if (err) throw err;
  7. ctx.body = {
  8. cde: 200,
  9. msg: `insert data to fe_frame success!`
  10. }
  11. resolve();
  12. })
  13. })
  14. })

重新执行node index.js,并使用浏览器访问localhost:3000/insert

插入多条数据

当访问/insertmulti时,用来插入多条数据:

</>复制代码

  1. router.get("/insertmulti", ctx => {
  2. return new Promise(resolve => {
  3. const sql = `INSERT INTO fe_frame(name, author)
  4. VALUES ?`;
  5. const values = [
  6. ["React", "Facebook"],
  7. ["Angular", "Google"],
  8. ["jQuery", "John Resig"]
  9. ];
  10. connection.query(sql, [values], (err, result) => {
  11. if (err) throw err;
  12. ctx.body = {
  13. code: 200,
  14. msg: `insert ${result.affectedRows} data to fe_frame success!`
  15. }
  16. resolve();
  17. })
  18. })
  19. })

重新执行node index.js,并使用浏览器访问localhost:3000/insertmulti

使用phpMyAdmin访问,可以看到此时mysqlkoa表如下

删除数据

当访问/delete时,删除相应行。我们使用请求参数name来指定删除哪个框架,在服务器端使用ctx.query.name获取,代码如下:

</>复制代码

  1. router.get("/delete", ctx => {
  2. return new Promise(resolve => {
  3. const name = ctx.query.name;
  4. const sql = `DELETE FROM fe_frame WHERE name = "${name}"`;
  5. connection.query(sql, (err, result) => {
  6. if (err) throw err;
  7. ctx.body = {
  8. code: 200,
  9. msg: `delete ${result.affectedRows} data from fe_frame success!`
  10. };
  11. resolve();
  12. })
  13. })
  14. })

重新执行node index.js,并使用浏览器访问http://localhost:3000/delete?name=jQuery

修改数据

当访问/update时,更新vue框架的作者名为Evan You,代码如下:

</>复制代码

  1. router.get("/update", ctx => {
  2. return new Promise(resolve => {
  3. const sql = `UPDATE fe_frame SET author = "Evan You" WHERE NAME = "vue"`;
  4. connection.query(sql, (err, result) => {
  5. if (err) throw err;
  6. ctx.body = {
  7. code: 200,
  8. msg: `update ${result.affectedRows} data from fe_frame success!`
  9. };
  10. resolve();
  11. })
  12. })
  13. })

重新执行node index.js,并使用浏览器访问http://localhost:3000/update

查找数据

当访问/select时,获取满足请求参数中框架名条件的项,代码如下:

</>复制代码

  1. router.get("/select", ctx => {
  2. return new Promise(resolve => {
  3. let name = ctx.query.name;
  4. const sql = `SELECT * FROM fe_frame WHERE name = "${name}"`;
  5. connection.query(sql, (err, result) => {
  6. if (err) throw err;
  7. ctx.body = {
  8. code: 200,
  9. data: result
  10. }
  11. resolve();
  12. })
  13. })
  14. })

重新执行node index.js,并使用浏览器访问http://localhost:3000/select?name=vue

</>复制代码

  1. mysql文档地址: https://www.npmjs.com/package...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/98792.html

相关文章

  • vue+node+mysql搭建个人博客(一)

    摘要:其中用来完成请求,将添加的原型上后就不需要再在每个需要使用它的页面引入了每个页面都相当于一个组件,文件以结尾,第一次启动成功时看到的页面就是组件,路径。 学习笔记...在线地址:cl8023.com github 数据库已改为mongodb 快速搭建 node 后端服务Github-quick-node-server 准备工作 安装node,这是必须的 新版node自带npm...

    peixn 评论0 收藏0
  • 一个简单express+jade+mysql+bootstrap+nodejs的demo

    摘要:迅速发展,目前最热的构建框架非莫属,在上有的就可以证明。下面就以为中心构建一个前后端都包含在内的简单吧。简单的能让你迅速地了解到工作流程。创建并初始化项目首先,进入到你的工作目录新建一个项目目录并打开通过命令为你的项目创建一个文件。 Nodejs迅速发展,目前最热的Nodejs构建框架非express莫属,在Github上有32k的star就可以证明。下面就以Nodejs为中心构建一个...

    sherlock221 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<