人妻精品在线观看一区二区三区,蜜臀av精品一区二区三区网站,中文一区二区三区亚洲欧美,熟女人妇精品一区二区,人妻av在线观看视频,欧美日韩国产三级精品网站,黄色免费网站直接进入,超碰公开福利正在播放,国产毛片乡下农村妇女毛片

聊聊node怎么操作MySQL數(shù)據(jù)庫(kù)(增刪改查)-世界新消息

來(lái)源:php中文網(wǎng) | 2023-02-28 19:45:33 |

node怎么操作MySQL數(shù)據(jù)庫(kù)?下面本篇文章帶大家了解一下node項(xiàng)目中MySQL數(shù)據(jù)庫(kù)增刪改查的方法,希望對(duì)大家有所幫助!

下載安裝mysql,檢查是否安裝成功

net start mysql
啟動(dòng)mysql可在桌面右鍵我的電腦進(jìn)入計(jì)算機(jī)管理查看mysql是否已經(jīng)成功運(yùn)行 【相關(guān)教程推薦:nodejs視頻教程】

下載安裝navicat

功能:為我們提供連接、操作mysql數(shù)據(jù)庫(kù)的功能

下載

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


(資料圖片僅供參考)

安裝

雙擊,一路next

使用

找到應(yīng)用程序,點(diǎn)擊啟動(dòng)

如果 連接測(cè)試通過(guò),接下來(lái)就可以點(diǎn)擊確定按鈕,正式連入mysql了。

連入后的效果如下:

數(shù)據(jù)庫(kù)簡(jiǎn)介

什么是數(shù)據(jù)庫(kù)

英文: database保存和管理數(shù)據(jù)的倉(cāng)庫(kù)就是數(shù)據(jù)庫(kù)。

什么是數(shù)據(jù)? 文件,圖片,視頻,訂單,用戶(hù)名,密碼等等。

這些數(shù)據(jù)都需要有專(zhuān)門(mén)的地方來(lái)保存和管理。

在我們沒(méi)有學(xué)習(xí)數(shù)據(jù)庫(kù)技術(shù)之前,我們使用的數(shù)據(jù)都是以文件系統(tǒng)(db.json)的方式保存的。我們需要一個(gè)專(zhuān)門(mén)的軟件來(lái)管理我們的數(shù)據(jù), 這就是數(shù)據(jù)庫(kù)。

兩大陣營(yíng)-數(shù)據(jù)庫(kù)分類(lèi)

關(guān)系型數(shù)據(jù)庫(kù),代表產(chǎn)品:

MySQLOracleSql serverDB2

非關(guān)系型數(shù)據(jù)庫(kù)

redis鍵值存儲(chǔ)數(shù)據(jù)庫(kù)HBaise列存儲(chǔ)數(shù)據(jù)庫(kù)mongodb面向文檔數(shù)據(jù)庫(kù)neo4j 圖形數(shù)據(jù)庫(kù)Elasticsearch 搜索引擎存儲(chǔ)

參考:數(shù)據(jù)庫(kù)使用排名 db-engines.com/en/ranking

理解關(guān)系型數(shù)據(jù)庫(kù)

在關(guān)系型數(shù)據(jù)庫(kù)中,存在三級(jí)關(guān)系:

數(shù)據(jù)庫(kù)數(shù)據(jù)表字段

類(lèi)比excel

每一列都是一類(lèi)數(shù)據(jù) --- 字段每一行代表一條數(shù)據(jù) --- 記錄
數(shù)據(jù)庫(kù)excel文件
數(shù)據(jù)庫(kù)excel文件
數(shù)據(jù)表excel文件中的某一個(gè)sheet
表結(jié)構(gòu):字段sheet中的表頭:列

MySQL簡(jiǎn)介

MySQL是一個(gè)關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),由瑞典MySQL AB 公司開(kāi)發(fā),目前屬于 Oracle 旗下產(chǎn)品 。MySQL所使用的 SQL 語(yǔ)言是用于訪問(wèn)數(shù)據(jù)庫(kù)的最常用標(biāo)準(zhǔn)化語(yǔ)言。

體積小、速度快、總體擁有成本低,一般中小型網(wǎng)站的開(kāi)發(fā)都選擇 MySQL 作為網(wǎng)站數(shù)據(jù)庫(kù)。搭配 PHP 和 Apache 可組成良好的開(kāi)發(fā)環(huán)境。

3p技術(shù):php,asp,jsp

操作數(shù)據(jù)庫(kù)-用navicat

新建數(shù)據(jù)庫(kù)

在彈出的窗口中填寫(xiě)數(shù)據(jù)庫(kù)名即可。

點(diǎn)擊確定之后,會(huì)在左側(cè)的數(shù)據(jù)庫(kù)列中看到上面創(chuàng)建成功的數(shù)據(jù)庫(kù)。

新建數(shù)據(jù)表

點(diǎn)擊 "新建表", 然后在開(kāi)始設(shè)置字段

設(shè)置字段完成之后,點(diǎn)擊上圖左上角所示的保存按鈕,就會(huì)進(jìn)一步彈出對(duì)話框,讓填寫(xiě)表的名字。

我們填入user

編輯字段

添加數(shù)據(jù)

一條內(nèi)容輸入完成后,按下tab,會(huì)自動(dòng)進(jìn)入下一條記錄的輸入

學(xué)習(xí)使用SQL語(yǔ)句

結(jié)構(gòu)化查詢(xún)語(yǔ)言(Structured Query Language)簡(jiǎn)稱(chēng)SQL,用來(lái)操作關(guān)系型數(shù)據(jù)庫(kù):

是一種數(shù)據(jù)庫(kù)查詢(xún)和程序設(shè)計(jì)語(yǔ)言,用來(lái)存取數(shù)據(jù)以及查詢(xún)、更新、和管理關(guān)系型數(shù)據(jù)庫(kù)。.sql是數(shù)據(jù)庫(kù)腳本文件的擴(kuò)展名。

最常用的用于數(shù)據(jù)操作的sql語(yǔ)句有四類(lèi),分別對(duì)應(yīng)對(duì)數(shù)據(jù)的四種操作:

增(create)(例如:用戶(hù)注冊(cè))刪(delete) (例如:刪除訂單)改(update) (例如:修改密碼)查(select , read) (例如:信息搜索)

在navicat中運(yùn)行sql - 添加數(shù)據(jù)

打開(kāi)sql編輯區(qū)

然后:

學(xué)習(xí) sql中的insert into 命令

格式:

insert into 表名(字段名1,字段名2,....)  values (值1,值2,....)

注意:

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

字段列表可以不與真實(shí)數(shù)據(jù)表中的字段完全相等,

可以省略一些不必要的字段順序與不需要與定義表時(shí)的順序一致

如果是字符串類(lèi)型的字段,其值要加"",如果是數(shù)值類(lèi)型的字符串,其值不需要加“”

示例:

insert into stu (sex, weight, name) values ("男", 60, "龐凱")

sql-delete語(yǔ)句-刪除數(shù)據(jù)

格式

delete  from 表名  where 刪除條件復(fù)制代碼

注意:不指定條件將刪除所有數(shù)據(jù)

示例

-- 刪除id為14的同學(xué)delete from stu where id=14-- 刪除的時(shí)候,不加條件,將刪除stu表中的全部記錄delete from stu

sql-update語(yǔ)句-修改數(shù)據(jù)

格式

update 表名 set 字段1=值1, 字段2=值2,...  where 修改條件

注意:

- 要修改的值使用鍵值對(duì)來(lái)表示 - 多個(gè)字段用,分隔- 不指定條件,將修改當(dāng)前表中全部的記錄

示例

-- 修改id為1的同學(xué)的年齡為53update stu set age=53 where id = 1-- 修改id為1的同學(xué)的年齡為35,身高為160update stu set age=35,height=160 where id = 1-- 如果修改的時(shí)候,不加條件,則會(huì)修改全部的數(shù)據(jù)update stu set weight = 60

sql-select-語(yǔ)句-數(shù)據(jù)查詢(xún)

作用

把數(shù)據(jù)從數(shù)據(jù)庫(kù)查出來(lái)

格式

SELECT  字段名1, 字段名2, .....  FROM 表名  WHERE <條件表達(dá)式>

示例

# 查詢(xún)部分字段SELECT id,name,age FROM stu# 查詢(xún)所有字段SELECT * FROM stu# 帶條件的查詢(xún)SELECT * FROM 表名 WHERE 條件1 and 條件2

where子句

select field1, field2... from 表名 查詢(xún)表中的所有數(shù)據(jù)

where 可以使用條件來(lái)篩選查詢(xún)出的結(jié)果

-- 查詢(xún)所有的學(xué)生select * from stu-- 查詢(xún)所有學(xué)生的id,name,heightselect id,name,height from stu-- 帶條件的查詢(xún)select * from stu where 條件-- 查詢(xún)所有的男同學(xué)select * from stu where sex="男"-- 查詢(xún)id為2的男同學(xué)select * from stu where id=2-- 查詢(xún)年齡大于50的同學(xué)select * from stu where age > 50-- 查詢(xún)年齡大于50歲的男同學(xué)select * from stu where age>50 and sex="男"-- 查詢(xún)年齡在30~60之間的同學(xué),包括30和60select * from stu where age>=30 and age<=60select * from stu where age between 30 and 60

node.js操作mysql

通過(guò)mysql這個(gè)包來(lái)操作mysql數(shù)據(jù)庫(kù)。

安裝包

mysql模塊是一個(gè)第三方模塊,專(zhuān)門(mén)用來(lái)操作MySQL數(shù)據(jù)庫(kù)。

# 安裝npm i mysql

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

使用步驟

要想用這個(gè)包連接數(shù)據(jù)庫(kù),首先要確保在電腦有mysql(phpstudy 還要啟動(dòng)mysql服務(wù))

一共需要4個(gè)步驟:

加載 MySQL 模塊

創(chuàng)建 MySQL 連接對(duì)象

連接 MySQL 服務(wù)器

執(zhí)行SQL語(yǔ)句

var mysql = require("mysql");var connection = mysql.createConnection({  host     : "localhost",   // 你要連接的數(shù)據(jù)庫(kù)服務(wù)器的地址  port     : 3306,// 端口號(hào)  user     : "root",        // 連接數(shù)據(jù)庫(kù)服務(wù)器需要的用戶(hù)名  password : "root",        // 連接數(shù)據(jù)庫(kù)服務(wù)器需要的密碼  database : "gz61"      //你要連接的數(shù)據(jù)庫(kù)的名字});connection.connect((err) => {  // 如果有錯(cuò)誤對(duì)象,表示連接失敗  if (err) return console.log("數(shù)據(jù)庫(kù)連接失敗")  // 沒(méi)有錯(cuò)誤對(duì)象提示連接成功  console.log("mysql數(shù)據(jù)庫(kù)連接成功")});

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

node操作mysql-查詢(xún)操作

執(zhí)行查詢(xún)類(lèi)型的SQL語(yǔ)句,查詢(xún)結(jié)果(result)是一個(gè)數(shù)組,每個(gè)單元是對(duì)象,對(duì)象的屬性是數(shù)據(jù)表的字段名。

// 1. 加載mysqlconst mysql = require("mysql");// 2. 創(chuàng)建連接對(duì)象const conn = mysql.createConnection({    // 對(duì)象的屬性名字不能改變    host: "localhost",    port: 3306,    user: "root",    password: "root",    database: "gz61"});// 3. 連接到MySQL服務(wù)器connection.connect((err) => {  // 如果有錯(cuò)誤對(duì)象,表示連接失敗  if (err) return console.log("數(shù)據(jù)庫(kù)連接失敗")  // 沒(méi)有錯(cuò)誤對(duì)象提示連接成功  console.log("mysql數(shù)據(jù)庫(kù)連接成功")});// 4. 執(zhí)行SQL語(yǔ)句let sql = "select id,name,age from stu";connection.query(sql, (err, result, fields) => {    if (err) throw err; // throw err 相當(dāng)于 return console.log(err);    console.log(result); // result就是查詢(xún)結(jié)果});

node操作mysql-添加操作

執(zhí)行添加類(lèi)型的SQL語(yǔ)句,查詢(xún)結(jié)果(result)是一個(gè)對(duì)象,該對(duì)象中有兩個(gè)屬性要關(guān)注:

affectedRows: 受影響行數(shù)insertID: 查詢(xún)數(shù)據(jù)的主鍵值
// 1. 加載mysqlconst mysql = require("mysql");// 2. 創(chuàng)建連接對(duì)象const conn = mysql.createConnection({    // 對(duì)象的屬性名字不能改變    host: "localhost",    port: 3306,    user: "root",    password: "root",    database: "gz61"});// 3. 連接到MySQL服務(wù)器connection.connect((err) => {  // 如果有錯(cuò)誤對(duì)象,表示連接失敗  if (err) return console.log("數(shù)據(jù)庫(kù)連接失敗")  // 沒(méi)有錯(cuò)誤對(duì)象提示連接成功  console.log("mysql數(shù)據(jù)庫(kù)連接成功")});let sql = "insert into users (name,password) values("小王","snv")"connection.query(sql, (err, result) => {    if (result.affectedRows > 0) {        console.log("添加成功,新數(shù)據(jù)的id為:" + result.insertId);    } else {        console.log("添加失敗");    }});

node操作mysql-修改操作

執(zhí)行修改類(lèi)型的SQL語(yǔ)句,查詢(xún)結(jié)果(result)是一個(gè)對(duì)象,該對(duì)象中有 affectedRows 屬性,表示本次修改操作影響到的行數(shù)。

// 1. 加載mysqlconst mysql = require("mysql");// 2. 創(chuàng)建連接對(duì)象const conn = mysql.createConnection({    // 對(duì)象的屬性名字不能改變    host: "localhost",    port: 3306,    user: "root",    password: "root",    database: "gz61"});// 3. 連接到MySQL服務(wù)器connection.connect((err) => {  // 如果有錯(cuò)誤對(duì)象,表示連接失敗  if (err) return console.log("數(shù)據(jù)庫(kù)連接失敗")  // 沒(méi)有錯(cuò)誤對(duì)象提示連接成功  console.log("mysql數(shù)據(jù)庫(kù)連接成功")});// 更新// 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-刪除操作

執(zhí)行刪除類(lèi)型的SQL語(yǔ)句,查詢(xún)結(jié)果(result)是一個(gè)對(duì)象,該對(duì)象中有 affectedRows 屬性

// 1. 加載mysqlconst mysql = require("mysql");// 2. 創(chuàng)建連接對(duì)象const conn = mysql.createConnection({    // 對(duì)象的屬性名字不能改變    host: "localhost",    port: 3306,    user: "root",    password: "root",    database: "gz61"});// 3. 連接到MySQL服務(wù)器connection.connect((err) => {  // 如果有錯(cuò)誤對(duì)象,表示連接失敗  if (err) return console.log("數(shù)據(jù)庫(kù)連接失敗")  // 沒(méi)有錯(cuò)誤對(duì)象提示連接成功  console.log("mysql數(shù)據(jù)庫(kù)連接成功")});// 刪除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 表名 條件會(huì)把數(shù)據(jù)直接從數(shù)據(jù)庫(kù)中刪除掉!

思路:

不是真的刪除,而是設(shè)置一個(gè)特殊的字段表示當(dāng)前的狀態(tài):正常還是已經(jīng)刪除
# 目標(biāo):把id=16的軟刪除掉update stu set isDelete=1 where id=16

模塊化封裝

分析上面幾個(gè)單獨(dú)的功能點(diǎn),它們基本的語(yǔ)法格式是一致的,只是要執(zhí)行的sql語(yǔ)句不同而已,所以,我們可以對(duì)它們進(jìn)行一個(gè)簡(jiǎn)單的封裝。然后再寫(xiě)測(cè)試文件對(duì)其進(jìn)行測(cè)試。

涉及兩個(gè)文件:

sql.jssqltest.js

封裝模塊

模塊名:sql.js

// 由于四項(xiàng)(insert,delete,update,select)操作只是sql語(yǔ)句不同// 1. 加載mysqlconst mysql = require("mysql");// 2. 創(chuàng)建連接對(duì)象const conn = mysql.createConnection({    // 對(duì)象的屬性名字不能改變    host: "localhost",    port: 3306,    user: "root",    password: "root",    database: "gz61"});// 3. 連接到MySQL服務(wù)器connection.connect((err) => {  // 如果有錯(cuò)誤對(duì)象,表示連接失敗  if (err) return console.log("數(shù)據(jù)庫(kù)連接失敗")  // 沒(méi)有錯(cuò)誤對(duì)象提示連接成功  console.log("mysql數(shù)據(jù)庫(kù)連接成功")});module.exports = connection

測(cè)試

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("用戶(hù)名密碼Ok");  } else {    console.log("用戶(hù)名密碼error");  }});

更多node相關(guān)知識(shí),請(qǐng)?jiān)L問(wèn):nodejs 教程!

以上就是聊聊node怎么操作MySQL數(shù)據(jù)庫(kù)(增刪改查)的詳細(xì)內(nèi)容,更多請(qǐng)關(guān)注php中文網(wǎng)其它相關(guān)文章!

關(guān)鍵詞: MySQL Node.js