mysql資料庫的一些用法,mysql資料庫常用語句

本文目錄一覽:

MySql操作「數據查詢」-20211222

# SELECT 數據查詢

## 基礎

顯示如何使用簡單的`select`語句查詢單個表中的數據 使用`SELECT`語句從表或視圖獲取數據。

表由行和列組成,如電子表格。 通常,我們只希望看到子集行,列的子集或兩者的組合。

SELECT語句的結果稱為結果集,它是行列表,每行由相同數量的列組成。

select 語法

SELECT語句由以下列表中所述的幾個子句組成:

1. SELECT 之後是逗號分隔列或星號(*)的列表,表示要返回所有列。

2. FROM 指定要查詢數據的表或視圖。

3. JOIN 根據某些連接條件從其他表中獲取數據。

4. WHER E過濾結果集中的行。

5. GROUP BY將一組行組合成小分組,並對每個小分組應用聚合函數。

6. HAVING 過濾器基於GROUP BY子句定義的小分組。

7. ORDER BY 指定用於排序的列的列表。

8. LIMIT 限制返回行的數量。

語句中的`SELECT`和`FROM`語句是必須的,其他部分是可選的。

`SELECT`語句允許通過在`SELECT`子句中指定逗號分隔列的列表來查詢表的部分數據

建議顯式獲取數據的列,原因如下:

1. 使用星號(*)可能會返回不使用的列的數據。 它在MySQL資料庫伺服器和應用程序之間產生不必要的I/O磁碟和網路流量。

2. 如果明確指定列,則結果集更可預測並且更易於管理。 想像一下,當您使用星號(*)並且有人通過添加更多列來更改表格數據時,將會得到一個與預期不同的結果集。

3. 使用星號(*)可能會將敏感信息暴露給未經授權的用戶

格式 `select 列篩選 form table where 行篩選`

還有一些有用的運算符可以在WHERE子句中使用來形成複雜的條件,例如:

BETWEEN 選擇在給定範圍之內的值。

LIKE 匹配基於模式匹配的值。

IN 指定值是否匹配列表中的任何值。

IS NULL 檢查該值是否為NULL。

## SELECT 子查詢

在一個查詢過程中 嵌套另一個查詢,子查詢的結果作為外部查詢的條件或者數據範圍來使用。

分為 3 類:

1. where 型

– `select展示列名 from 表名 where 列名 運算符[in…] (select 對應列名 from …)`

– 這個列名 和 對應列名 應該做到類型相同

– 如果不加入運算符 也可使用IN 這些類似的符號 – `select 展示列名 from 表名 where 列名 in (select 對應列名 from …)`

– ex:

`select 展示列名 from 表名 where 列名 ALL(select 對應列名 from ….)`;

比子查詢的值都大

`select 展示列名 from 表名 where 列名 ANY(select 對應列名 from ….);`

比子查詢的任意一個值大

2. from 型

– `select 展示列名 from 表名 inner join (select 列名 from …) 臨時表名 on 條件;`

– 其中,select的子查詢所得的表 為臨時表,後跟臨時表名,可在條件判斷中指代

3. exist 型

– `select 展示列 from 表名 where exists (select 列名 from 表名 where 條件);`

– 將主查詢的結果帶入子查詢進行條件判斷和匹配,如果查詢出結果即保留。

## 去重 DISTINCT

SELECT 語句執行簡單的數據查詢時,返回的是所有匹配的記錄。`distinct` 實現查詢不重複的數據

**DISTINCT 關鍵字的主要作用就是對數據表中一個或多個欄位重複的數據進行過濾,只返回其中的一條數據給用戶。**

使用 `DISTINCT` 關鍵字時需要注意以下幾點:

– `DISTINCT` 關鍵字只能在 `SELECT` 語句中使用。

– 在對一個或多個欄位去重時,`DISTINCT` 關鍵字必須在所有欄位的最前面。

– 如果 `DISTINCT` 關鍵字後有多個欄位,則會對多個欄位進行組合去重,也就是說,只有多個欄位組合起來完全是一樣的情況下才會被去重。

## 指定別名 AS

### 1. 為表指定別名

1. 當表名很長的時候 或者 執行了一些特殊的查詢的時候,為方便操作,可以為表指定一個別名,用以替代原來的名稱

2. 語法.

3. `表名 as 別名` – 含義: – `表名` : 資料庫中存儲的數據表名稱。

– `別名` : 查詢的時候指定的新的名稱。

– `as` : 此關鍵字 可以 省略,省略之後要將 `表名`與`別名`用 `空格` 分開

** *注意:表的別名不能與該資料庫的其它表同名。欄位的別名不能與該表的其它欄位同名。在條件表達式中不能使用欄位的別名,否則會出現「ERROR 1054 (42S22): Unknown column」這樣的錯誤提示信息。* **

*** ex1:

***

### 2. 為欄位指定別名

1. 在使用 SELECT 語句查詢數據時,MySQL 會顯示每個 SELECT 後面指定輸出的欄位。有時為了顯示結果更加直觀,我們可以為欄位指定一個別名。

2. 語法:

3. `欄位名 [AS] 別名`

– 含義:

– `欄位名`:為數據表中欄位定義的名稱。

– `欄位別名`:欄位新的名稱。

– `AS` 關鍵字可以省略,省略後需要將欄位名和別名用空格隔開

** *注意:表別名只在執行查詢時使用,並不在返回結果中顯示。而欄位定義別名之後,會返回給客戶端顯示,顯示的欄位為欄位的別名* ** ***

ex2:

***

## 限制查詢條數 LIMIT

1. LIMIT 關鍵字有 3 種使用方式,即

– `指定初始位置`、

– `不指定初始位置`

– `OFFSET 組合`使用

(。。。。。 我之前一直不知道, 只會使用 `limit 200`。。。。。)

### 指定初始位置

1. 語法

– `LIMIT 初始位置,記錄數`

– 初始位置」表示從哪條記錄開始顯示;第一條記錄的位置是 0,第二條記錄的位置是 1。後面的記錄依次類推。

– 「記錄數」表示顯示記錄的條數。

– *LIMIT 後的兩個參數必須都是正整數。

* ex:tb_students_info 表中,使用 LIMIT 子句返回從第 4 條記錄開始的行數為 5 的記錄,SQL 語句和運行結果如下。

### 不指定初始位置

記錄從第一條記錄開始顯示。顯示記錄的條數由 LIMIT 關鍵字指定。

1. 語法

– `LIMIT 5`

– `SELECT * FROM tb_students_info LIMIT 15;`

### LIMIT 和 OFFSET 組合使用

1. 語法

– `LIMIT 記錄數 OFFSET 初始位置`

– 參數和 LIMIT 語法中參數含義相同,「初始位置」指定從哪條記錄開始顯示;「記錄數」表示顯示記錄的條數。

該語句返回的是從第 4 條記錄開始的之後的 5 條記錄。即「 LIMIT 5 OFFSET 3 」意思是獲取從第 4 條記錄開始的後面的 5 條記錄,和「 LIMIT 3 , 5 」返回的結果相同。

*** 2021-12-22 今天先學到這裡 明天繼續 MySql 的查詢 學習

如何使用MySQL資料庫,MySQL的使用方法

如何使用MySQL資料庫,MySQL的使用方法

在Windows下,假如你的MySQL裝在 D:\MySQL

就可以這樣:

先切換到它的bin目錄

cd D:\MySQL\bin\

D:\MySQL\binmysql -u root -p

接著輸入你的root密碼

接下來你就可以創建資料庫、創建用戶、創建修改表之類的操作(常用命令如下)。

查看現有資料庫

mysql show databases;

創建資料庫(假如資料庫名為 mydb)

mysql create database mydb;

刪除資料庫(假如資料庫名為 mydb)

mysql drop database accounts;

使用資料庫(假如使用資料庫 mydb)

mysql use mydb;

執行完使用資料庫命令後,就可以對該資料庫進行創建、修改、插入、刪除表等操作,這些表的操作命令你可以到網上找找,不是很難的。一個資料庫就相當於一個 Excel 文件,而表則相當於Excel文件的單元格,數據就是存放在表中。

MySQL資料庫必會技能,虛擬列的用法

對於想要將自動生成的數據添加到表中的任何人來說, MySQL 虛擬列 是一個強大、易於使用和高級的功能。

INSERT 生成的列允許您在不使用and UPDATE 子句的情況下將自動生成的數據存儲在表中。 這個有用的特性自 5.7 版 起就已成為 MySQL 的一部分,它代表了在生成數據時觸發器的另一種方法。此外,生成的列可以幫助您更輕鬆、更高效地查詢。

虛擬列 列類似於普通列,但您不能手動更改其值。這是因為表達式定義了如何根據從同一行的其他列中讀取的其他值來生成生成列的值。因此,生成的列在表的域內工作,其定義不能涉及 JOIN 語句。

換句話說,您可以將生成的列視為一種視圖,但僅限於列。請注意,生成的列與 SQL 觸發器 不同,您只能在使用 CREATE TABLE or語句時定義它們,語法如下: ALTER TABLE

該 AS (generated_column_expression) 子句指定要添加或更新到表中的列是生成的列。定義 MySQL 將用於計算列值的 generation_expression 表達式,它不能引用另一個生成的列或除當前表的列之外的任何內容。另外,請注意生成表達式只能涉及不可變函數。例如,您不能在生成的列表達式定義中使用返回當前日期的函數,因為它是一個可變函數。

您還可以在關鍵字前面 AS 加上 GENERATED ALWAYS 關鍵字以使生成的列的性質更加明確,但這是可選的。然後,您可以指示生成列的類型是 VIRTUAL 還是 STORED 。您將在下面的章節中了解這兩種類型之間的區別。默認情況下,如果沒有在查詢中明確指定,MySQL 會將生成的列標記為 VIRTUAL .

現在讓我們看看生成的列語法在 CREATE TABLE 查詢中的作用:

在此示例中,該 full_name 列將自動存儲 first_name 和 last_name 列的連接。

如前所述,您可以將生成的列定義為 VIRTUAL 或 STORED。現在讓我們仔細看看這兩種類型。

MySQL 不存儲標記為 VIRTUAL 的 虛擬列 。這意味著 MySQL 在需要時動態評估其值。 BEFORE 這通常在觸發任何查詢後立即發生。換句話說,虛擬生成的列不佔用存儲空間。

MySQL 存儲任何生成的標記為 STORED 的列。這意味著每次插入或更新行時,MySQL 都會評估其值並將其存儲在磁碟上。換句話說,存儲列需要存儲空間,就好像它是普通列一樣。

現在讓我們進一步了解虛擬列和存儲生成列的優缺點。

優點

缺點

優點

缺點

採用生成的列有幾個原因,但以下三個是最重要的。

如您所見,您可以通過將四列與以下生成的列聚合來輕鬆生成此數據欄位:

這將產生:

在這種情況下,生成的列使您能夠直接在資料庫級別標準化數據欄位格式。此外,存儲生成的列避免了每次需要時都構造此欄位的不可避免的開銷。

通常,您使用網站 URL 中的資源 ID 或REST API來檢索您需要的數據。但是公開暴露您的 ID 可能會帶來安全問題。當您發現自己使用自動增量 ID 時尤其如此,這很容易預測並使抓取或機器人攻擊更容易。

為避免這種情況,您可以考慮通過使用自動生成的、隨機的、更安全的公共 ID 來隱藏您的原始 ID。您可以通過對您的 ID 進行散列處理,使用虛擬生成的列來實現這一點,如下所示:

請注意,為避免生成已知的哈希值,您可以將您的 ID 與特殊關鍵字連接起來。 在此處了解有關 MySQL 加密和壓縮功能的更多信息。

過濾數據時,有些列比其他列更有用。此外,您通常必須更改存儲在列中的值的表示形式,以使過濾更簡單或更直觀。您可以定義一個有用的生成列來存儲以所需格式執行過濾所需的信息,而不是在每個過濾器查詢中執行此操作。

例如,您可以定義一個生成的列,以便更輕鬆地找到籃球隊中的球員,如下所示:

這樣的列將產生:

如前所述,您只能在表中使用生成的列。此外,它們只能涉及不可變函數,並且MySQL 生成它們的值以響應 INSERT or UPDATE 查詢。另一方面,觸發器是 MySQL 自動執行的存儲程序,每當與特定表關聯的 或 事件發生 INSERT 時 UPDATE 。 DELETE 換句話說,觸發器可以涉及多個表和所有 MySQL 函數。與生成的列相比,這使它們成為更完整的解決方案。同時,MySQL 觸發器本質上使用和定義更複雜,也比生成的列慢。

mysql使用教程?

MySQL資料庫使用教程介紹

完整 MySQL 操作詳見:[MySQL攻略]MySQL資料庫使用教程介紹

什麼叫MySQL資料庫?

資料庫(Database)是依照演算法設計來機構、儲存和管理數據信息的倉庫。每一個資料庫都具有一個或多個API用以創建,訪問,管理,檢索和拷貝存儲的數據信息。

如今大家用的大多數是關係型資料庫管理系統(RDBMS)來儲存和管理大量數據。所謂關係型資料庫,就是以關係模型為基礎的資料庫,憑藉結合集合代數等數學概念來對資料庫中的數據進行處理。

MySQL是時下最熱門的關係型資料庫管理系統之一,本教程將會講解MySQL的基礎知識,並幫助大家熟練應用MySQL資料庫。

MySQL教程-RDBMS專業術語

在開始學習MySQL資料庫前,使我們先掌握下RDBMS的一些專業術語:

資料庫:資料庫是一些關係表的結合。

數據表:數據的矩陣。在一個資料庫中的表看上去像一個簡易的excel表。

列:一列(數據元素)包括了同類型的數據。

行:一行(元組/紀錄)是一組有關的數據。

冗餘:儲存二倍數據,性能會有所損失,但信息安全性有所提高。

主鍵:主鍵是唯一的。一個數據表中只有包含一個主鍵。

外鍵:用於關聯兩個表。

索引:用資料庫索引可快速訪問數據表中的特定信息。索引是對資料庫表格中一列或多列的值作排列的一種構造方式。類似書本的目錄。

MySQL教程-基礎操作

進到資料庫:mysql -uroot -p,登陸密碼立即回車鍵

退出資料庫:quit或是exit

查詢版本號:select version();

獲取當前時間:select now();

mysql建立的資料庫怎麼使用

mysql創建資料庫命令:1.show databases //顯示資料庫

2.create database student(資料庫名) //創建資料庫student

3.use student //進入student資料庫

4.create table studinfo(表名) (sno int primary key,sage int(2))

………… // 創建表studinfo

5.show table //顯示錶

…………..

6.drop database student //刪除student資料庫

原創文章,作者:TYFOV,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/317099.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
TYFOV的頭像TYFOV
上一篇 2025-01-11 16:27
下一篇 2025-01-11 16:27

相關推薦

  • 如何修改mysql的埠號

    本文將介紹如何修改mysql的埠號,方便開發者根據實際需求配置對應埠號。 一、為什麼需要修改mysql埠號 默認情況下,mysql使用的埠號是3306。在某些情況下,我們需…

    編程 2025-04-29
  • Python3支持多行語句

    Python3是一種高級編程語言,開發人員可以輕鬆地使用該語言編寫簡單到複雜的代碼。其中Python3支持多行語句,方便開發人員編寫複雜的代碼,提高代碼的可讀性和可維護性。 一、使…

    編程 2025-04-29
  • Python 常用資料庫有哪些?

    在Python編程中,資料庫是不可或缺的一部分。隨著互聯網應用的不斷擴大,處理海量數據已成為一種趨勢。Python有許多成熟的資料庫管理系統,接下來我們將從多個方面介紹Python…

    編程 2025-04-29
  • openeuler安裝資料庫方案

    本文將介紹在openeuler操作系統中安裝資料庫的方案,並提供代碼示例。 一、安裝MariaDB 下面介紹如何在openeuler中安裝MariaDB。 1、更新軟體源 sudo…

    編程 2025-04-29
  • Python for循環語句列印九九乘法表

    本篇文章將詳細介紹如何使用Python的for循環語句列印九九乘法表。列印九九乘法表是我們初學Python時經常練習的一項基礎操作,也是編寫Python程序的基本能力之一。 1、基…

    編程 2025-04-29
  • Python中while語句和for語句的區別

    while語句和for語句是Python中兩種常見的循環語句,它們都可以用於重複執行一段代碼。然而,它們的語法和適用場景有所不同。本文將從多個方面詳細闡述Python中while語…

    編程 2025-04-29
  • Python操作MySQL

    本文將從以下幾個方面對Python操作MySQL進行詳細闡述: 一、連接MySQL資料庫 在使用Python操作MySQL之前,我們需要先連接MySQL資料庫。在Python中,我…

    編程 2025-04-29
  • Python中自定義函數必須有return語句

    自定義函數是Python中最常見、最基本也是最重要的語句之一。在Python中,自定義函數必須有明確的返回值,即必須要有return語句。本篇文章將從以下幾個方面對此進行詳細闡述。…

    編程 2025-04-29
  • 資料庫第三範式會有刪除插入異常

    如果沒有正確設計資料庫,第三範式可能導致刪除和插入異常。以下是詳細解釋: 一、什麼是第三範式和範式理論? 範式理論是關係資料庫中的一個規範化過程。第三範式是範式理論中的一種常見形式…

    編程 2025-04-29
  • MySQL遞歸函數的用法

    本文將從多個方面對MySQL遞歸函數的用法做詳細的闡述,包括函數的定義、使用方法、示例及注意事項。 一、遞歸函數的定義 遞歸函數是指在函數內部調用自身的函數。MySQL提供了CRE…

    編程 2025-04-29

發表回復

登錄後才能評論