MySQL最基本的概念梳理

来源:http://www.cnblogs.com/mesopotamia/archive/2017/08/22/7407487.html
-Advertisement-
Play Games

本文根據《MySQL必知必會》(Ben Forta著,2009)整理,基於MySQL4.1-5,可作為深入研究MySQL之前的漱口篇。(基本語句、正則表達式、聯結、全文本搜索、增刪改查、存儲過程、游標、觸發器、事務、索引)。 ...


 

本文根據《MySQL必知必會》(Ben Forta著,2009)整理,基於MySQL4.1-5,可作為深入研究MySQL之前的漱口篇。(基本語句、正則表達式、聯結、全文本搜索、增刪改查、存儲過程、游標、觸發器、事務、索引)。

 

基本語句


 

limit:使用limit(x,y)進行分頁等;

 

NULL判斷:Select xxx from yyy where xxx IS NULL;

 

優先順序:Select prod_name,prod_price from products where vend_id=1002 or vend_id=1003 and prod_price>=10;And 優先於 or;

 

匹配:%與_,後者匹配單個字元;

 

去空:RTrim(xxx),去掉值右邊所有空格;LTrim(xxx),去掉值左邊空格;Trim(),去掉兩邊空格;

 

拼接,重命名:Select concat(vend_name,’(’,vend_country,’)’)as vend_file from vendors;

 

字元串處理:Left()、Length()、Locate()找一個串的子串、Lower()大轉小、Right()、Soundex()、SubString()、Upper()小轉大;

 

日期時間:AddDate()、AddTime()、CurDate()、CurTime()、Date()、DateDiff()、Date_Add()、Date_Format()、Day()、DayOfWeek()、Hour()、Minute()、Month()、Now()、Second()、Time()、Year()。MySQL的日期格式:yyyy-mm-dd;

 

數據處理:Abs()絕對值、Cos()、Exp()指數、Mod()除餘、Pi()、Rand()隨機、Sin()、Sqrt()平方根、Tan();

 

聚集:AVG()平均值、COUNT()行數、MAX()最大值、MIN()最小值、SUM()求和;

 

Select子句順序:select,from,where,group by,having,order by,limit

 

正則表達式


 

REGEXP:Prod_name包含文本1000的:select prod_name from products where prod_name REGEXP’1000’ order by prod_name;

 

匹配任意一個字元:… where prod_name REGEXP’.000’;

 

BINARY:正則匹配不區分大小寫,匹配要加BINARY,如:where prod_name REGEXP BINARY ‘JetPack.000’;

 

OR匹配:where prod_name REGEXP ‘1000|2000’;

 

匹配幾個字元之一:where prod_name REGEXP ‘[123]Ton’;

 

匹配範圍:where prod_name REGEXP’[1-5]Ton’;

 

匹配特殊字元需要轉義:where vend_name REGEXP’\\.’;

 

\\也用於元字元:\\f換頁,\\n換行,\\t製表,\\r回車,\\v縱向製表;

 

聯結與組合


 

等值聯結

 

 

笛卡爾積

Select vend_name,prod_name,prod_price from vendors,products order by vend_name,prod_name;

 

內部聯結

 

自聯結

等價於:

 

自然聯結(排除多次出現,每個列只返回一次):

 

外部聯結(包含了在相關表中沒有關聯行的行):

Left(right) outer join:左(右)邊表中選中所有行;

 

全文本搜索


 

MySQL常用的兩種引擎:MyISAM(支持全文搜索)InnoDB(不支持全文搜索);

 

啟動全文本搜索

 

方法:Macth()+Against()

等價於:

 

前者是按等級降序,後者不會;前者有索引,更快。

 

可以在select中加一個計算列:

 

查詢擴展:MySQL對數據和索引進行兩遍掃描,第一遍進行基本的全文搜索,找出與條件匹配的所有行àMySQL檢查這些匹配行,選擇所有有用的詞àMySQL再進行全文搜索,使用原來條件+所有有用的詞。

 

 

增刪改查


 

一般刪除用delete,更快刪除用truncate table(刪除原來的表,新建一個表)。

 

Mysql沒有撤銷按鈕,需要小心使用update和delete。

 

創建表

 

 

創建多個主鍵

 

主鍵是單個,則單個列值唯一,主鍵時多個,則多個組合起來唯一。

 

Select last_insert_id()返回最後一個AUTO_INCREMENT值。

 

引擎類型:MySQL有一個具體管理和處理數據的內部引擎,通過引擎創建表,內部處理你的查詢等請求。

 

三種引擎InnoDB,可靠的事務處理引擎,不支持全文本搜索;MEMORY功能等同於MyISAM,但數據存儲在記憶體(不是磁碟中),速度快(適合臨時表);MyISAM,性能極高,支持全文本搜索,不支持事務處理;

 

增加列:alter table vendors add vend_phone char(20);

 

刪除列:alter table vendors drop column vend_phone;

 

存儲過程


 

創建存儲過程

 

調用存儲過程

 

刪除

 

 

使用參數

 

調用帶參存儲過程

 

獲取結果

 

同時使用IN和OUT

 

調用IN和OUT存儲過程

 

智能存儲過程

 

顯示用來創建一個存儲過程的create語句

SHOW CREATE PROCEDURE ordertotal;

 

獲得何時、由誰創建等詳細信息

SHOW PROCEDURE STATUS LIKE ‘ordertotal’;

 

游標


 

游標是一個存儲在MySQL伺服器上的資料庫查詢,是被查詢語句檢索出來的結果集。存儲游標後,應用程式根據需要滾動或瀏覽數據。MySQL游標只能用於存儲過程(和函數)。

 

創建游標

 

存儲過程處理完成後,游標即消失(僅用於存儲過程)。

 

 

打開游標

OPEN ordernumbers;

 

關閉游標

CLOSE ordernumbers;

 

使用FETCH訪問游標的每一行,指定檢索什麼數據(列),檢索的數據存在何處,向前移動游標的內部行指針以檢索下一行:

 

使用游標迴圈檢索數據(你可以在迴圈內放入任何需要的處理):

 

對取出的數據做一個實際的處理:

 

觸發器


 

在某個表發生更改時(DELETE、INSERT、UPDATE)自動處理某些事情。

 

創建觸發器:需要給出四條信息:唯一的觸發器名、關聯的表、應該響應的活動(刪除、插入、更新)、何時執行(處理前、後)。

 

觸發器僅支持表(視圖、臨時表均不支持)。

 

刪除觸發器

 

INSERT觸發器:使用NEW虛擬表訪問被插入的行。

 

DELETE觸發器:引用OLD虛擬表訪問被刪除的行:

上例使用BEGIN…END為非必須,BEGIN…END的好處:可容納多條SQL語句。

 

UPDATE觸發器:引用OLD訪問更新前的值,引用NEW訪問更新後的值。

 

事務


 

事務處理用來維護資料庫的完整性,它保證成批的MySQL要麼完全執行,要麼完全不執行。

 

關於事務的名詞:回退、提交、保留點(事務處理中設定的臨時占位符,可對它發佈回退)。

 

事務的開始

 

使用ROLLBACK:

 

使用COMMIT:一般的MySQL預設自動提交。但在事務處理塊兒中,提交不會預設進行:

 

使用保留點:簡單的ROLLBACK和COMMIT會寫入或撤銷整個事務處理。複雜的事務處理需要部分提交或回退。這時需要在事務處理塊兒的合適位置放置占位符。

 

更改預設的提交行為

 

索引


 

創建索引(INDEX:普通;PRIMARY KEY:唯一且不能為空;UNIQUE:唯一且不允許重覆):

 

 

刪除索引

 

更多精彩掃描本人微信公眾號二維碼(it_pupil)

 


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

-Advertisement-
Play Games
更多相關文章
  • MTK刷機工具Flash_Tool部分4032錯誤解決辦法 先說明一點,這個辦法不是萬能的,我測試解決了以下兩種情況下的4032: 1、本來正常的開發板,因為一次刷機失敗後就一直變4032了 2、新開發板,第一次刷機就4032(在硬體正常的情況下,如果硬體有問題的話,呵呵,老夫掐之一算,累死也刷不進 ...
  • // NSFontAttributeName 設置字體屬性,預設值:字體:Helvetica(Neue) 字型大小:12 // NSForegroundColorAttributeNam 設置字體顏色,取值為 UIColor對象,預設值為黑色 // NSBackgroundColorAttributeN ...
  • 對很多做設計或產品的小伙伴們來說,Sketch應該不會陌生。它是一款由Bohemian Coding團隊一手打造的矢量繪圖應用軟體,最初發佈於2010年,後在2012年榮獲Apple公司ADA設計獎項。從產品開發及功能側重點來講,很多人會認為Sketch是專為UI設計師打造、擅長也只能用於UI設計, ...
  • 項目經過一個月的加班加點,終於這一期算是差不多了,於是便開始了優化工作,今天就發現了一個問題,在iOS10.2系統一下的手機調用系統的撥打電話功能,彈框是不出現的,直接跳轉到撥打電話的界面,但是在iOS10.2及其以上的系統是會出現的,這裡項目的代碼是一樣的,相信開發者都認識,如下 最後查閱資料才知 ...
  • 轉載請說明來源: http://www.cnblogs.com/lizhilin2016/p/7390079.html 最近lz 在開始做一個新的Demo, 在項目中集成了bugly用於收集項目中的崩潰日誌, 集成Bmob用於作為後臺資料庫, 集成了友盟用於集成第三方分享, 當然了, 這些都有很多方 ...
  • 代碼: AppDelegate.m ...
  • 1 概述 1 概述 本篇文章簡要對事物與鎖的分析比較詳細,因此就轉載了。 2 具體內容 2 具體內容 併發可以定義為多個進程同時訪問或修改共用數據的能力。處於活動狀態而互不幹涉的併發用戶進程的數量越多,資料庫系統的併發性就越好。當一個正在修改數據的進程阻止了其他進程讀取該數據,或者當一個正在讀取數據 ...
  • 1 概述 1 概述 本文將結合MSDN簡要概述JSON數據。 2 具體內容 2 具體內容 JSON 是一種流行的數據格式,用於在現代 Web 和移動應用程式中交換數據。 JSON 還可用於在 Microsoft Azure DocumentDB 等 NoSQL 資料庫中存儲非結構化數據。 許多 RE ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...