聊聊node怎麼操作MySQL資料庫(增刪改查)

2023-02-28 22:00:21

node怎麼操作MySQL資料庫?下面本篇文章帶大家瞭解一下node專案中MySQL資料庫增刪改查的方法,希望對大家有所幫助!

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


image.png

net start mysql
登入後複製
  • 啟動mysql
  • 可在桌面右鍵我的電腦進入計算機管理檢視mysql是否已經成功執行 【相關教學推薦:】

image.png

下載安裝navicat


功能:為我們提供連線、操作mysql資料庫的功能

下載

安裝

雙擊,一路next

使用

找到應用程式,點選啟動

image.png

如果 連線測試通過,接下來就可以點選確定按鈕,正式連入mysql了。image.png

連入後的效果如下:

image.png

資料庫簡介


什麼是資料庫

英文: database 儲存和管理資料的倉庫就是資料庫。

什麼是資料? 檔案,圖片,視訊,訂單,使用者名稱,密碼等等。

這些資料都需要有專門的地方來儲存和管理。

在我們沒有學習資料庫技術之前,我們使用的資料都是以檔案系統(db.json)的方式儲存的。我們需要一個專門的軟體來管理我們的資料, 這就是資料庫。

image.png

兩大陣營-資料庫分類

  • 關係型資料庫,代表產品:

    • MySQL
    • Oracle
    • Sql server
    • DB2
  • 非關係型資料庫

    • redis 鍵值儲存資料庫
    • HBaise列儲存資料庫
    • mongodb 面向檔案資料庫
    • neo4j 圖形資料庫
    • Elasticsearch 搜尋引擎儲存

參考:資料庫使用排名

image.png

理解關係型資料庫

在關係型資料庫中,存在三級關係:

  • 資料庫
  • 資料表
  • 欄位

類比excel

image.png

  • 每一列都是一類資料 --- 欄位
  • 每一行代表一條資料 --- 記錄
資料庫excel檔案
資料庫excel檔案
資料表excel檔案中的某一個sheet
表結構:欄位sheet中的表頭:列

MySQL簡介

image.pngMySQL是一個關係型資料庫管理系統,由瑞典MySQL AB 公司開發,目前屬於 Oracle 旗下產品 。MySQL所使用的 SQL 語言是用於存取的最常用標準化語言。

  • 體積小、速度快、總體擁有成本低,一般中小型網站的開發都選擇 MySQL 作為網站資料庫。
  • 搭配 和 可組成良好的開發環境。

3p技術:php,asp,jsp

運算元據庫-用navicat


新建資料庫

image.png

在彈出的視窗中填寫資料庫名即可。

image.png點選確定之後,會在左側的資料庫列中看到上面建立成功的資料庫。

新建資料表

image.png

點選 "新建表", 然後在開始設定欄位

image.png

主鍵: 作用是區別一條資料和其它資料。(它相當於人的身份證號)

設定欄位完成之後,點選上圖左上角所示的儲存按鈕,就會進一步彈出對話方塊,讓填寫表的名字。

我們填入user

image.png

編輯欄位

image.png

新增資料

image.png

一條內容輸入完成後,按下tab,會自動進入下一條記錄的輸入

學習使用SQL語句


結構化查詢語言(Structured Query Language)簡稱SQL,用來操作關係型資料庫:

  • 是一種資料庫查詢和程式設計語言,用來存取資料以及查詢、更新、和管理關係型資料庫。
  • .sql是資料庫指令碼檔案的擴充套件名。

最常用的用於資料操作的sql語句有四類,分別對應對資料的四種操作:

  • 增(create)(例如:使用者註冊)
  • 刪(delete) (例如:刪除訂單)
  • 改(update) (例如:修改密碼)
  • 查(select , read) (例如:資訊搜尋)

在navicat中執行sql - 新增資料


開啟sql編輯區

image.png

然後:

image.png

學習 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的同學的年齡為53
update stu set age=53 where id = 1

-- 修改id為1的同學的年齡為35,身高為160
update 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,height
select 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和60
select * from stu where age>=30 and age<=60
select * from stu where age between 30 and 60
登入後複製

node.js操作mysql


通過mysql這個包來操作mysql資料庫。

安裝包

mysql模組是一個第三方模組,專門用來操作MySQL資料庫。

# 安裝
npm i mysql
登入後複製

參考:

使用步驟

要想用這個包連線資料庫,首先要確保在電腦有mysql(phpstudy 還要啟動mysql服務)

一共需要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資料庫連線成功')
});
登入後複製

參考地址:

node操作mysql-查詢操作


執行查詢型別的SQL語句,查詢結果(result)是一個陣列,每個單元是物件,物件的屬性是資料表的欄位名。

// 1. 載入mysql
const 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. 載入mysql
const 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. 載入mysql
const 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=11
let 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. 載入mysql
const 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 表名 條件 會把資料直接從資料庫中刪除掉!

思路:

  • 不是真的刪除,而是設定一個特殊的欄位表示當前的狀態:正常還是已經刪除

image.png

# 目標:把id=16的軟刪除掉
update stu set isDelete=1 where id=16
登入後複製

模組化封裝


分析上面幾個單獨的功能點,它們基本的語法格式是一致的,只是要執行的sql語句不同而已,所以,我們可以對它們進行一個簡單的封裝。然後再寫測試檔案對其進行測試。

涉及兩個檔案:

  • sql.js
  • sqltest.js

封裝模組

模組名:sql.js

// 由於四項(insert,delete,update,select)操作只是sql語句不同

// 1. 載入mysql
const 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相關知識,請存取:!

以上就是聊聊node怎麼操作MySQL資料庫(增刪改查)的詳細內容,更多請關注TW511.COM其它相關文章!