亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

node操作MySQL數據庫的方法有哪些

發布時間:2023-03-01 09:44:26 來源:億速云 閱讀:138 作者:iii 欄目:web開發

這篇文章主要介紹“node操作MySQL數據庫的方法有哪些”,在日常操作中,相信很多人在node操作MySQL數據庫的方法有哪些問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”node操作MySQL數據庫的方法有哪些”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

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

node操作MySQL數據庫的方法有哪些

net start mysql
  • 啟動mysql

  • 可在桌面右鍵我的電腦進入計算機管理查看mysql是否已經成功運行 

node操作MySQL數據庫的方法有哪些

下載安裝navicat

功能:為我們提供連接、操作mysql數據庫的功能

安裝

雙擊,一路next

使用

找到應用程序,點擊啟動

node操作MySQL數據庫的方法有哪些

如果 連接測試通過,接下來就可以點擊確定按鈕,正式連入mysql了。node操作MySQL數據庫的方法有哪些

連入后的效果如下:

node操作MySQL數據庫的方法有哪些

數據庫簡介

什么是數據庫

英文: database 保存和管理數據的倉庫就是數據庫。

什么是數據? 文件,圖片,視頻,訂單,用戶名,密碼等等。

這些數據都需要有專門的地方來保存和管理。

在我們沒有學習數據庫技術之前,我們使用的數據都是以文件系統(db.json)的方式保存的。我們需要一個專門的軟件來管理我們的數據, 這就是數據庫。

node操作MySQL數據庫的方法有哪些

兩大陣營-數據庫分類

  • 關系型數據庫,代表產品:

    • MySQL

    • Oracle

    • Sql server

    • DB2

  • 非關系型數據庫

    • redis 鍵值存儲數據庫

    • HBaise列存儲數據庫

    • mongodb 面向文檔數據庫

    • neo4j 圖形數據庫

    • Elasticsearch 搜索引擎存儲

node操作MySQL數據庫的方法有哪些

理解關系型數據庫

在關系型數據庫中,存在三級關系:

  • 數據庫

  • 數據表

  • 字段

類比excel

node操作MySQL數據庫的方法有哪些

  • 每一列都是一類數據 --- 字段

  • 每一行代表一條數據 --- 記錄

數據庫excel文件
數據庫excel文件
數據表excel文件中的某一個sheet
表結構:字段sheet中的表頭:列

MySQL簡介

MySQL是一個關系型數據庫管理系統,由瑞典MySQL AB 公司開發,目前屬于 Oracle 旗下產品 。MySQL所使用的 SQL 語言是用于訪問數據庫的最常用標準化語言。

  • 體積小、速度快、總體擁有成本低,一般中小型網站的開發都選擇 MySQL 作為網站數據庫。

  • 搭配 PHP 和 Apache 可組成良好的開發環境。

3p技術:php,asp,jsp

操作數據庫-用navicat

新建數據庫

node操作MySQL數據庫的方法有哪些

在彈出的窗口中填寫數據庫名即可。

node操作MySQL數據庫的方法有哪些點擊確定之后,會在左側的數據庫列中看到上面創建成功的數據庫。

新建數據表

node操作MySQL數據庫的方法有哪些

點擊 "新建表", 然后在開始設置字段

node操作MySQL數據庫的方法有哪些

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

設置字段完成之后,點擊上圖左上角所示的保存按鈕,就會進一步彈出對話框,讓填寫表的名字。

我們填入user

node操作MySQL數據庫的方法有哪些

編輯字段

node操作MySQL數據庫的方法有哪些

添加數據

node操作MySQL數據庫的方法有哪些

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

學習使用SQL語句

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

  • 是一種數據庫查詢和程序設計語言,用來存取數據以及查詢、更新、和管理關系型數據庫。

  • .sql是數據庫腳本文件的擴展名。

最常用的用于數據操作的sql語句有四類,分別對應對數據的四種操作:

  • 增(create)(例如:用戶注冊)

  • 刪(delete) (例如:刪除訂單)

  • 改(update) (例如:修改密碼)

  • 查(select , read) (例如:信息搜索)

在navicat中運行sql - 添加數據

打開sql編輯區

node操作MySQL數據庫的方法有哪些

然后:

node操作MySQL數據庫的方法有哪些

學習 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 表名 條件 會把數據直接從數據庫中刪除掉!

思路:

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

node操作MySQL數據庫的方法有哪些

# 目標:把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操作MySQL數據庫的方法有哪些”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

舒城县| 楚雄市| 峨山| 深水埗区| 肇源县| 台东县| 平利县| 双流县| 安阳县| 和田市| 漳平市| 平南县| 务川| 二连浩特市| 太保市| 乌拉特中旗| 毕节市| 房产| 洞头县| 耒阳市| 阳山县| 革吉县| 北川| 军事| 无极县| 新平| 贡觉县| 盈江县| 宾川县| 峡江县| 阜阳市| 温泉县| 宁陵县| 泾川县| 禹州市| 河曲县| 丽江市| 宝坻区| 万州区| 大港区| 金山区|