观热点:聊聊node怎么操作MySQL数据库(增删改查)

时间:2023-02-28 20:11:54       来源:转载

node怎么操作MySQL数据库?下面本篇文章带大家了解一下node项目中MySQL数据库增删改查的方法,希望对大家有所帮助!


(相关资料图)

下载安装mysql,检查是否安装成功


net start mysql
登录后复制
启动mysql可在桌面右键我的电脑进入计算机管理查看mysql是否已经成功运行 【相关教程推荐:nodejs视频教程】

下载安装navicat


功能:为我们提供连接、操作mysql数据库的功能

下载

www.navicat.com.cn/products#na…

安装

双击,一路next

使用

找到应用程序,点击启动

如果 连接测试通过,接下来就可以点击确定按钮,正式连入mysql了。

连入后的效果如下:

数据库简介


什么是数据库

英文: database保存和管理数据的仓库就是数据库。

什么是数据? 文件,图片,视频,订单,用户名,密码等等。

这些数据都需要有专门的地方来保存和管理。

在我们没有学习数据库技术之前,我们使用的数据都是以文件系统(db.json)的方式保存的。我们需要一个专门的软件来管理我们的数据, 这就是数据库。

两大阵营-数据库分类

关系型数据库,代表产品:

MySQLOracleSql serverDB2

非关系型数据库

redis键值存储数据库HBaise列存储数据库mongodb面向文档数据库neo4j 图形数据库Elasticsearch 搜索引擎存储

参考:数据库使用排名 db-engines.com/en/ranking

理解关系型数据库

在关系型数据库中,存在三级关系:

数据库数据表字段

类比excel

每一列都是一类数据 --- 字段每一行代表一条数据 --- 记录
数据库excel文件
数据库excel文件
数据表excel文件中的某一个sheet
表结构:字段sheet中的表头:列

MySQL简介

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品 。MySQL所使用的 SQL 语言是用于访问数据库的最常用标准化语言。

体积小、速度快、总体拥有成本低,一般中小型网站的开发都选择 MySQL 作为网站数据库。搭配 PHP 和 Apache 可组成良好的开发环境。

3p技术:php,asp,jsp

操作数据库-用navicat


新建数据库

在弹出的窗口中填写数据库名即可。

点击确定之后,会在左侧的数据库列中看到上面创建成功的数据库。

新建数据表

点击 "新建表", 然后在开始设置字段

设置字段完成之后,点击上图左上角所示的保存按钮,就会进一步弹出对话框,让填写表的名字。

我们填入user

编辑字段

添加数据

一条内容输入完成后,按下tab,会自动进入下一条记录的输入

学习使用SQL语句


结构化查询语言(Structured Query Language)简称SQL,用来操作关系型数据库:

是一种数据库查询和程序设计语言,用来存取数据以及查询、更新、和管理关系型数据库。.sql是数据库脚本文件的扩展名。

最常用的用于数据操作的sql语句有四类,分别对应对数据的四种操作:

增(create)(例如:用户注册)删(delete) (例如:删除订单)改(update) (例如:修改密码)查(select , read) (例如:信息搜索)

在navicat中运行sql - 添加数据


打开sql编辑区

然后:

学习 sql中的insert into 命令

格式:

insert into 表名(字段名1,字段名2,....)  values (值1,值2,....)
登录后复制

注意:

字段的顺序要和值的顺序是完全匹配的

字段列表可以不与真实数据表中的字段完全相等,

可以省略一些不必要的字段顺序与不需要与定义表时的顺序一致

如果是字符串类型的字段,其值要加"",如果是数值类型的字符串,其值不需要加“”

示例:

insert into stu (sex, weight, name) values ("男", 60, "庞凯")
登录后复制

sql-delete语句-删除数据


格式

delete  from 表名  where 删除条件复制代码
登录后复制

注意:不指定条件将删除所有数据

示例

-- 删除id为14的同学delete from stu where id=14-- 删除的时候,不加条件,将删除stu表中的全部记录delete from stu
登录后复制

sql-update语句-修改数据


格式

update 表名 set 字段1=值1, 字段2=值2,...  where 修改条件
登录后复制

注意:

- 要修改的值使用键值对来表示 - 多个字段用,分隔- 不指定条件,将修改当前表中全部的记录
登录后复制

示例

-- 修改id为1的同学的年龄为53update stu set age=53 where id = 1-- 修改id为1的同学的年龄为35,身高为160update stu set age=35,height=160 where id = 1-- 如果修改的时候,不加条件,则会修改全部的数据update stu set weight = 60
登录后复制

sql-select-语句-数据查询


作用

把数据从数据库查出来

格式

SELECT  字段名1, 字段名2, .....  FROM 表名  WHERE <条件表达式>
登录后复制

示例

# 查询部分字段SELECT id,name,age FROM stu# 查询所有字段SELECT * FROM stu# 带条件的查询SELECT * FROM 表名 WHERE 条件1 and 条件2
登录后复制

where子句


select field1, field2... from 表名 查询表中的所有数据

where 可以使用条件来筛选查询出的结果

-- 查询所有的学生select * from stu-- 查询所有学生的id,name,heightselect id,name,height from stu-- 带条件的查询select * from stu where 条件-- 查询所有的男同学select * from stu where sex="男"-- 查询id为2的男同学select * from stu where id=2-- 查询年龄大于50的同学select * from stu where age > 50-- 查询年龄大于50岁的男同学select * from stu where age>50 and sex="男"-- 查询年龄在30~60之间的同学,包括30和60select * from stu where age>=30 and age<=60select * from stu where age between 30 and 60
登录后复制

node.js操作mysql


通过mysql这个包来操作mysql数据库。

安装包

mysql模块是一个第三方模块,专门用来操作MySQL数据库。

# 安装npm i mysql
登录后复制

参考:www.npmjs.com/package/mys…

使用步骤

一共需要4个步骤:

加载 MySQL 模块

创建 MySQL 连接对象

连接 MySQL 服务器

执行SQL语句

var mysql = require("mysql");var connection = mysql.createConnection({  host     : "localhost",   // 你要连接的数据库服务器的地址  port     : 3306,// 端口号  user     : "root",        // 连接数据库服务器需要的用户名  password : "root",        // 连接数据库服务器需要的密码  database : "gz61"      //你要连接的数据库的名字});connection.connect((err) => {  // 如果有错误对象,表示连接失败  if (err) return console.log("数据库连接失败")  // 没有错误对象提示连接成功  console.log("mysql数据库连接成功")});
登录后复制

参考地址: www.npmjs.com/package/mys…

node操作mysql-查询操作


执行查询类型的SQL语句,查询结果(result)是一个数组,每个单元是对象,对象的属性是数据表的字段名。

// 1. 加载mysqlconst mysql = require("mysql");// 2. 创建连接对象const conn = mysql.createConnection({    // 对象的属性名字不能改变    host: "localhost",    port: 3306,    user: "root",    password: "root",    database: "gz61"});// 3. 连接到MySQL服务器connection.connect((err) => {  // 如果有错误对象,表示连接失败  if (err) return console.log("数据库连接失败")  // 没有错误对象提示连接成功  console.log("mysql数据库连接成功")});// 4. 执行SQL语句let sql = "select id,name,age from stu";connection.query(sql, (err, result, fields) => {    if (err) throw err; // throw err 相当于 return console.log(err);    console.log(result); // result就是查询结果});
登录后复制

node操作mysql-添加操作


执行添加类型的SQL语句,查询结果(result)是一个对象,该对象中有两个属性要关注:

affectedRows: 受影响行数insertID: 查询数据的主键值
// 1. 加载mysqlconst mysql = require("mysql");// 2. 创建连接对象const conn = mysql.createConnection({    // 对象的属性名字不能改变    host: "localhost",    port: 3306,    user: "root",    password: "root",    database: "gz61"});// 3. 连接到MySQL服务器connection.connect((err) => {  // 如果有错误对象,表示连接失败  if (err) return console.log("数据库连接失败")  // 没有错误对象提示连接成功  console.log("mysql数据库连接成功")});let sql = "insert into users (name,password) values("小王","snv")"connection.query(sql, (err, result) => {    if (result.affectedRows > 0) {        console.log("添加成功,新数据的id为:" + result.insertId);    } else {        console.log("添加失败");    }});
登录后复制

node操作mysql-修改操作


执行修改类型的SQL语句,查询结果(result)是一个对象,该对象中有 affectedRows 属性,表示本次修改操作影响到的行数。

// 1. 加载mysqlconst mysql = require("mysql");// 2. 创建连接对象const conn = mysql.createConnection({    // 对象的属性名字不能改变    host: "localhost",    port: 3306,    user: "root",    password: "root",    database: "gz61"});// 3. 连接到MySQL服务器connection.connect((err) => {  // 如果有错误对象,表示连接失败  if (err) return console.log("数据库连接失败")  // 没有错误对象提示连接成功  console.log("mysql数据库连接成功")});// 更新// update stu set 字段=值,字段=值 where id=11let sql = "update users set password="123" where name="小王"";conn.query(sql, (err, result) => {    if (err) throw err;    if (result.affectedRows > 0) {        console.log("修改成功");    } else {        console.log("修改失败");    }})
登录后复制

node操作mysql-删除操作


执行删除类型的SQL语句,查询结果(result)是一个对象,该对象中有 affectedRows 属性

// 1. 加载mysqlconst mysql = require("mysql");// 2. 创建连接对象const conn = mysql.createConnection({    // 对象的属性名字不能改变    host: "localhost",    port: 3306,    user: "root",    password: "root",    database: "gz61"});// 3. 连接到MySQL服务器connection.connect((err) => {  // 如果有错误对象,表示连接失败  if (err) return console.log("数据库连接失败")  // 没有错误对象提示连接成功  console.log("mysql数据库连接成功")});// 删除let sql = "delete from stu where id=1";connection.query(sql,(err, result) => {    if (err) throw err;    if (result.affectedRows > 0) {        console.log("删除成功");    } else {        console.log("删除失败");    }});
登录后复制

了解一下软删除


做删除 : delete from 表名 条件会把数据直接从数据库中删除掉!

思路:

不是真的删除,而是设置一个特殊的字段表示当前的状态:正常还是已经删除
# 目标:把id=16的软删除掉update stu set isDelete=1 where id=16
登录后复制

模块化封装


分析上面几个单独的功能点,它们基本的语法格式是一致的,只是要执行的sql语句不同而已,所以,我们可以对它们进行一个简单的封装。然后再写测试文件对其进行测试。

涉及两个文件:

sql.jssqltest.js

封装模块

模块名:sql.js

// 由于四项(insert,delete,update,select)操作只是sql语句不同// 1. 加载mysqlconst mysql = require("mysql");// 2. 创建连接对象const conn = mysql.createConnection({    // 对象的属性名字不能改变    host: "localhost",    port: 3306,    user: "root",    password: "root",    database: "gz61"});// 3. 连接到MySQL服务器connection.connect((err) => {  // 如果有错误对象,表示连接失败  if (err) return console.log("数据库连接失败")  // 没有错误对象提示连接成功  console.log("mysql数据库连接成功")});module.exports = connection
登录后复制

测试

sqltest.js

const conn = require("./sql");conn.query("select * from users where username="小美1" and userpassword="666"", (err, data) => {  console.log(err);  console.log(data);  if (data.length > 0) {    console.log("用户名密码Ok");  } else {    console.log("用户名密码error");  }});
登录后复制

更多node相关知识,请访问:nodejs 教程!

以上就是聊聊node怎么操作MySQL数据库(增删改查)的详细内容,更多请关注php中文网其它相关文章!

关键词: 数据库连接 连接失败 数据库服务器