二、MySQL基礎操作

来源:https://www.cnblogs.com/TheHypocrite/p/18286788
-Advertisement-
Play Games

二、MySQL基礎操作 1. 資料庫操作 顯示所有資料庫 SHOW DATABASES; 創建資料庫 CREATE DATABASE MyDb; 刪除資料庫 -- 直接刪除庫,不檢查是否存在 DROP DATABASE MyDb; -- 或檢查是否存在 DROP DATABASE [IF EXIST ...


二、MySQL基礎操作

1. 資料庫操作

顯示所有資料庫

SHOW DATABASES;

創建資料庫

CREATE DATABASE MyDb;

刪除資料庫

-- 直接刪除庫,不檢查是否存在
DROP DATABASE MyDb;
-- 或檢查是否存在
DROP DATABASE [IF EXISTS] MyDb;

2. 表操作

選擇資料庫

USE MyDb;

創建表

CREATE TABLE Tb ( id INT(11), name VARCHAR(32), weigh FLOAT );

查看表結構

DESC Tb;

刪除表

-- 直接刪除表,不檢查是否存在
DROP TABLE Tb ;
-- 或檢查是否存在
DROP TABLE [IF EXISTS] Tb;

設置主鍵

-- 直接在創建表時設置主鍵
CREATE TABLE Tb ( id INT(11) PRIMARY KEY, name VARCHAR(32), weigh FLOAT );
-- 或者在創建表後設置主鍵
ALTER TABLE Tb ADD PRIMARY KEY (id);

聯合主鍵

CREATE TABLE Tb ( id INT(11), name VARCHAR(32), weigh FLOAT, PRIMARY KEY (id, name) );

設置外鍵

ALTER TABLE 表名 ADD CONSTRAINT 外鍵名 FOREIGN KEY (欄位名) REFERENCES 主表名 (主鍵名);

添加約束

-- 唯一約束
ALTER TABLE Tb ADD UNIQUE (欄位名);

-- 非空約束
ALTER TABLE Tb MODIFY 欄位名 數據類型 NOT NULL;

-- 預設約束
ALTER TABLE Tb MODIFY 欄位名 數據類型 DEFAULT 預設值;

設置自動增加

ALTER TABLE Tb MODIFY id INT(11) AUTO_INCREMENT;

查看表詳細結構

SHOW CREATE TABLE Tb;

修改表結構

-- 更改表名
ALTER TABLE 舊表名 RENAME TO 新表名;

-- 修改欄位名
ALTER TABLE 表名 CHANGE 舊欄位名 新欄位名 新數據類型;

-- 修改欄位數據類型
ALTER TABLE 表名 MODIFY 欄位名 新數據類型;

-- 添加欄位
ALTER TABLE 表名 ADD 新欄位名 新數據類型 約束條件;

-- 在第一列添加欄位
ALTER TABLE 表名 ADD 新欄位名 新數據類型 約束條件 FIRST;

-- 在指定列後面添加欄位
ALTER TABLE 表名 ADD 新欄位名 新數據類型 約束條件 AFTER 指定列;

修改欄位排列位置

-- 修改為表的第一個欄位
ALTER TABLE 表名 MODIFY 欄位名 新數據類型 FIRST;

-- 修改為指定列後
ALTER TABLE 表名 MODIFY 欄位名 新數據類型 AFTER 指定列;

刪除表的外鍵約束

ALTER TABLE 表名 DROP FOREIGN KEY 外鍵名;

3. 數據操作

插入數據

INSERT INTO 表名 (欄位1, 欄位2, 欄位3, 欄位n) VALUES (數據1, 數據2, 數據3, 數據n), (數據1, 數據2, 數據3, 數據n), ...;

更新數據

UPDATE 表名 SET 欄位1 = "值", 欄位2 = 數值 WHERE 過濾條件;

刪除數據

-- 根據條件刪除
DELETE FROM 表名 WHERE 條件語句;

-- 刪除所有行
DELETE FROM 表名;

4. 查詢操作

基本查詢語句

-- 查詢某欄位
SELECT 欄位1, 欄位2 FROM 表名;

-- 查詢全部欄位
SELECT * FROM 表名;

條件查詢

-- 帶IN關鍵字查詢
SELECT 欄位1, 欄位2 FROM 表名 WHERE 欄位 IN (值1, 值2, 值3, ...);

SELECT 欄位1, 欄位2 FROM 表名 WHERE 欄位 NOT IN (值1, 值2, 值3, ...);

-- 帶BETWEEN AND的範圍查詢
SELECT 欄位1, 欄位2 FROM 表名 WHERE 欄位 BETWEEN 值1 AND 值2;

SELECT 欄位1, 欄位2 FROM 表名 WHERE 欄位 NOT BETWEEN 值1 AND 值2;

-- 帶LIKE的字元匹配查詢
SELECT 欄位1, 欄位2 FROM 表名 WHERE 欄位 LIKE '%字元%';

SELECT 欄位1, 欄位2 FROM 表名 WHERE 欄位 LIKE '______字元';

-- 查詢空值
SELECT 欄位1, 欄位2 FROM 表名 WHERE 欄位 IS NULL;

-- 去除重覆項
SELECT DISTINCT 欄位 FROM 表名;

-- 帶AND與OR的多條件查詢
SELECT 欄位1, 欄位2 FROM 表名 WHERE 欄位1 條件語句 AND 欄位2 條件語句;

SELECT 欄位1, 欄位2 FROM 表名 WHERE 欄位1 條件語句 OR 欄位2 條件語句;
( 雖然兩種寫法功能一樣,但是我們更推薦使用 IN 關鍵字。因為它不僅邏輯清晰,執行的速度也會快於 OR 關鍵字。更重要的是,使用 IN 關鍵字,我們以後可以執行更加複雜的嵌套語句。)

排序與分組

-- 對查詢結果進行排序
SELECT 欄位1, 欄位2 FROM 表名 ORDER BY 欄位 [ASC|DESC];

-- 分組查詢
SELECT 欄位1, 欄位2 FROM 表名 GROUP BY 欄位;查詢的是每個分組中 首次出現的一條記錄。

限制查詢結果

-- 查詢前x條數據
SELECT 欄位1, 欄位2 FROM 表名 LIMIT x;查詢表中前x條數據。

-- 從a往後查詢b條數據,不包含a
SELECT 欄位1, 欄位2 FROM 表名 LIMIT a, b;


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 測試環境中,新搭建的Oracle 19c DG,在主備切換後,新的主庫的告警日誌中一直出現類似下麵這樣的錯誤: .........................................2024-07-08T13:40:55.384302+08:00 rfs (PID:146054): Da ...
  • redis筆記 1. Redis是什麼? Redis( Remote Dictionary Server )是一個使用 C 語言編寫的,高性能非關係型的鍵值對資料庫。 與傳統資料庫不同的是,Redis 的數據是存在記憶體中的,所以讀寫速度非常快,被廣泛應用於緩存方 向。Redis可以將數據寫入磁碟中, ...
  • 各位熱愛Apache DolphinScheduler的小伙伴們,社區6月月報更新啦!這裡將記錄Apache DolphinScheduler社區每月的重要更新,歡迎關註。 月度Merge Stars 感謝以下小伙伴上個月為Apache DolphinScheduler所做的精彩貢獻(排名不分先後) ...
  • 各位熱愛Apache SeaTunnel的小伙伴們,社區6月份月報來啦!這裡將記錄Apache SeaTunnel社區每月的重要更新,歡迎關註。 月度Merge Stars 感謝以下小伙伴上個月為Apache SeaTunnel所做的精彩貢獻(排名不分先後): @baicie,@TaoZex,@lo ...
  • 設想我們在一家很大的互聯網公司做IT方面的規劃、開發和維護,有以下這樣的應用場景: 公司里有若幹個不同的開發團隊,開發語言有Java、.net、Python、C++....十來種,還有很多外包團隊對項目進行開發,大中小系統已經多的數不過來;並且各個團隊、系統間都需要進行海量數據的交換(比如搜索引擎實 ...
  • GaussDB(DWS)成功將Greenplum上數萬個數據模型、數萬個代碼腳本、數百萬行代碼全部遷移至安全可控的數據倉庫平臺。 ...
  • MySql 1. 事務的四大特性? 事務特性ACID:原子性(Atomicity)、一致性(Consistency)、隔離性(Isolation)、持久性(Durability)。 1.原子性是指事務包含的所有操作要麼全部成功,要麼全部失敗回滾。 2.一致性是指一個事務執行之前和執行之後都必須處於一 ...
  • 《Spark 快速大數據分析》是一本為 Spark 初學者準備的書,它沒有過多深入實現細節,而是更多關註上層用戶的具體用法。不過,本書絕不僅僅限於 Spark 的用法,它對 Spark 的核心概念和基本原理也有較為全面的介紹,讓讀者能夠知其然且知其所以然。 Spark快速大數據分析PDF下載 本書作 ...
一周排行
    -Advertisement-
    Play Games
  • 通過WPF的按鈕、文本輸入框實現了一個簡單的SpinBox數字輸入用戶組件並可以通過數據綁定數值和步長。本文中介紹了通過Xaml代碼實現自定義組件的佈局,依賴屬性的定義和使用等知識點。 ...
  • 以前,我看到一個朋友在對一個系統做初始化的時候,通過一組魔幻般的按鍵,調出來一個隱藏的系統設置界面,這個界面在常規的菜單或者工具欄是看不到的,因為它是一個後臺設置的關鍵界面,不公開,同時避免常規用戶的誤操作,它是作為一個超級管理員的入口功能,這個是很不錯的思路。其實Winform做這樣的處理也是很容... ...
  • 一:背景 1. 講故事 前些天有位朋友找到我,說他的程式每次關閉時就會自動崩潰,一直找不到原因讓我幫忙看一下怎麼回事,這位朋友應該是第二次找我了,分析了下 dump 還是挺經典的,拿出來給大家分享一下吧。 二:WinDbg 分析 1. 為什麼會崩潰 找崩潰原因比較簡單,用 !analyze -v 命 ...
  • 在一些報表模塊中,需要我們根據用戶操作的名稱,來動態根據人員姓名,更新報表的簽名圖片,也就是電子手寫簽名效果,本篇隨筆介紹一下使用FastReport報表動態更新人員簽名圖片。 ...
  • 最新內容優先發佈於個人博客:小虎技術分享站,隨後逐步搬運到博客園。 創作不易,如果覺得有用請在Github上為博主點亮一顆小星星吧! 博主開始學習編程於11年前,年少時還只會使用cin 和cout ,給單片機點點燈。那時候,類似async/await 和future/promise 模型的認知還不是 ...
  • 之前在阿裡雲ECS 99元/年的活動實例上搭建了一個測試用的MINIO服務,以前都是直接當基礎設施來使用的,這次準備自己學一下S3相容API相關的對象存儲開發,因此有了這個小工具。目前僅包含上傳功能,後續計劃開發一個類似圖床的對象存儲應用。 ...
  • 目錄簡介快速入門安裝 NuGet 包實體類User資料庫類DbFactory增刪改查InsertSelectUpdateDelete總結 簡介 NPoco 是 PetaPoco 的一個分支,具有一些額外的功能,截至現在 github 星數 839。NPoco 中文資料沒多少,我是被博客園群友推薦的, ...
  • 前言 前面使用 Admin.Core 的代碼生成器生成了通用代碼生成器的基礎模塊 分組,模板,項目,項目模型,項目欄位的基礎功能,本篇繼續完善,實現最核心的模板生成功能,並提供生成預覽及代碼文件壓縮下載 準備 首先清楚幾個模塊的關係,如何使用,簡單畫一個流程圖 前面完成了基礎的模板組,模板管理,項目 ...
  • 假設需要實現一個圖標和文本結合的按鈕 ,普通做法是 直接重寫該按鈕的模板; 如果想作為通用的呢? 兩種做法: 附加屬性 自定義控制項 推薦使用附加屬性的形式 第一種:附加屬性 創建Button的附加屬性 ButtonExtensions 1 public static class ButtonExte ...
  • 在C#中,委托是一種引用類型的數據類型,允許我們封裝方法的引用。通過使用委托,我們可以將方法作為參數傳遞給其他方法,或者將多個方法組合在一起,從而實現更靈活的編程模式。委托類似於函數指針,但提供了類型安全和垃圾回收等現代語言特性。 基本概念 定義委托 定義委托需要指定它所代表的方法的原型,包括返回類 ...