欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL對標準SQL的擴展方式

 更新時間:2025年02月27日 11:00:20   作者:費曼樂園  
MySQL對標準SQL的擴展包括磁盤上的數據組織方式、通用語言語法、SQL語句語法、數據類型、函數和運算符等,這些擴展使得MySQL在某些方面與其他SQL數據庫管理系統(tǒng)不同

MySQL對標準SQL的擴展

MySQL服務器支持一些其他SQL數據庫管理系統(tǒng)中不太可能找到的擴展功能。請注意,如果您使用這些擴展功能,您的代碼可能無法在其他SQL服務器上移植。

在某些情況下,您可以編寫包含MySQL擴展功能但仍然可移植的代碼,通過使用以下形式的注釋:

/*! MySQL-specific code */

在這種情況下,MySQL服務器解析并執(zhí)行注釋中的代碼,就像處理任何其他SQL語句一樣,但其他SQL服務器應該忽略這些擴展功能。

例如,MySQL服務器可以識別以下語句中的STRAIGHT_JOIN關鍵字,但其他服務器則不會:

SELECT /*! STRAIGHT_JOIN */ col1 FROM table1,table2 WHERE ...

如果在'!'字符之后添加版本號,那么注釋中的語法只有在MySQL版本大于或等于指定的版本號時才會執(zhí)行。

以下注釋中的KEY_BLOCK_SIZE子句僅在MySQL 5.1.10或更高版本的服務器上執(zhí)行:

CREATE TABLE t1(a INT, KEY (a)) /*!50110 KEY_BLOCK_SIZE=1024 */;

以下描述按照類別列出了MySQL的擴展功能:

磁盤上的數據組織方式

MySQL服務器將每個數據庫映射到MySQL數據目錄下的一個目錄,并將數據庫中的表映射到數據庫目錄中的文件名。因此,在具有區(qū)分大小寫文件名的操作系統(tǒng)上(例如大多數Unix系統(tǒng)),MySQL服務器中的數據庫和表名區(qū)分大小寫。

通用語言語法

  • 默認情況下,字符串可以用雙引號 " 或單引號 ' 括起來。如果啟用了ANSI_QUOTES SQL模式,則字符串只能用單引號 ' 括起來,而服務器將雙引號括起來的字符串解釋為標識符。
  • \ 是字符串中的轉義字符。
  • 在SQL語句中,您可以使用db_name.tbl_name語法訪問不同數據庫中的表。一些SQL服務器提供相同的功能,但將其稱為用戶空間。MySQL服務器不支持類似以下語句中使用的表空間:CREATE TABLE ralph.my_table ... IN my_tablespace。

SQL語句語法

  • ANALYZE TABLE、CHECK TABLE、OPTIMIZE TABLE和REPAIR TABLE語句。
  • CREATE DATABASE、DROP DATABASE和ALTER DATABASE語句。
  • DO語句。
  • 使用EXPLAIN SELECT語句可以獲取查詢優(yōu)化器處理表的描述。
  • FLUSH和RESET語句。
  • SET語句。
  • SHOW語句。許多MySQL特定的SHOW語句產生的信息可以通過使用SELECT查詢INFORMATION_SCHEMA以更標準的方式獲得。
  • LOAD DATA的用法。在許多情況下,此語法與Oracle的LOAD DATA兼容。
  • RENAME TABLE的用法。
  • 使用REPLACE而不是DELETE加INSERT的用法。
  • 在ALTER TABLE語句中使用CHANGE col_name、DROP col_name、DROP INDEX、IGNORE或RENAME的用法。在ALTER TABLE語句中使用多個ADD、ALTER、DROP或CHANGE子句的用法。
  • 在CREATE TABLE語句中使用索引名稱、創(chuàng)建列前綴索引、以及使用INDEX或KEY的用法。
  • 在CREATE TABLE語句中使用TEMPORARY或IF NOT EXISTS的用法。
  • 使用IF EXISTS的用法在DROP TABLE和DROP DATABASE語句中。
  • 使用單個DROP TABLE語句刪除多個表的功能。
  • UPDATE和DELETE語句中的ORDER BY和LIMIT子句的用法。
  • INSERT INTO tbl_name SET col_name = ...語法的用法。
  • INSERT和REPLACE語句的DELAYED子句的用法。
  • 在SELECT語句中使用INTO OUTFILE或INTO DUMPFILE的用法。
  • 在SELECT語句中使用STRAIGHT_JOIN或SQL_SMALL_RESULT等選項的用法。
  • 在GROUP BY子句中不需要為所有選擇的列命名。這對于一些非常特定但相當常見的查詢可以提供更好的性能。
  • 可以在GROUP BY子句中使用ASC和DESC來指定排序順序,而不僅僅是在ORDER BY子句中使用。
  • 使用:=賦值運算符在語句中設置變量的能力。

數據類型

  • 中等整數類型(MEDIUMINT),集合類型(SET),枚舉類型(ENUM),以及各種二進制大對象(BLOB)和文本(TEXT)類型。
  • AUTO_INCREMENT(自動遞增)、BINARY(二進制)、NULL(空值)、UNSIGNED(無符號)和ZEROFILL(填充零)是數據類型的屬性。

函數和運算符(Functions and operators)

  • 為了方便從其他SQL環(huán)境遷移的用戶,MySQL Server支持許多函數的別名。例如,所有字符串函數都支持標準SQL語法和ODBC語法。
  • MySQL Server 中的 || 和 && 運算符被理解為邏輯 OR 和 AND,在 C 編程語言中也是如此。在 MySQL Server 中,|| 和 OR 是同義詞,&& 和 AND 也是如此。由于這種優(yōu)雅的語法,MySQL Server 不支持標準的 SQL || 運算符用于字符串連接;而是使用 CONCAT() 函數來進行字符串連接。由于 CONCAT() 函數接受任意數量的參數,因此很容易將使用 || 運算符的代碼轉換為 MySQL Server 的語法。
  • 使用 COUNT(DISTINCT value_list) 的情況是 value_list 包含多個元素。
  • 字符串比較在默認情況下是不區(qū)分大小寫的,排序順序由當前字符集的校對規(guī)則(默認為utf8mb4)確定。若要執(zhí)行大小寫敏感的比較,您可以在聲明列時使用BINARY屬性,或者使用BINARY轉換操作符,這樣比較將使用底層字符代碼值而不是詞法順序進行。
  • % 運算符是 MOD() 的同義詞。也就是說,N % M 等同于 MOD(N, M)。% 運算符支持給 C 程序員使用,并且與 PostgreSQL 兼容性保持一致。
  • 在SELECT語句中,可以在輸出列列表(在FROM左側)的表達式中使用=、<>, <=、<、>=、>、<<、>>、<=>、AND、OR或LIKE運算符。
  • 例如:
mysql> SELECT col1=1 AND col2=2 FROM my_table;
  • LAST_INSERT_ID() 函數返回最近插入的 AUTO_INCREMENT 值。
  • LIKE 運算符允許在數值上使用。
  • REGEXP和NOT REGEXP是擴展正則表達式運算符。它們用于在比較中使用正則表達式來匹配或排除模式。
  • CONCAT() 或者 CHAR() 函數可以接受一個或多個參數。在 MySQL Server 中,這些函數可以接受可變數量的參數。
  • BIT_COUNT()、CASE、ELT()、FROM_DAYS()、FORMAT()、IF()、MD5()、PERIOD_ADD()、PERIOD_DIFF()、TO_DAYS() 和 WEEKDAY() 是MySQL中可用的一些函數。
  • 使用 TRIM() 函數來修剪子字符串。標準 SQL 只支持刪除單個字符。
  • GROUP BY 函數包括 STD()、BIT_OR()、BIT_AND()、BIT_XOR() 和 GROUP_CONCAT() 。

總結

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 關于mysql基礎知識的介紹

    關于mysql基礎知識的介紹

    本篇文章是對mysql的基礎知識進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • MySql中的IFNULL、NULLIF和ISNULL用法詳解

    MySql中的IFNULL、NULLIF和ISNULL用法詳解

    本文主要介紹了MySql中的IFNULL、NULLIF和ISNULL用法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-03-03
  • 創(chuàng)建mysql表分區(qū)的方法

    創(chuàng)建mysql表分區(qū)的方法

    我來給大家介紹一下mysql表分區(qū)創(chuàng)建與使用吧,希望對各位同學會有所幫助。表分區(qū)的測試使用,主要內容來自于其他博客文章以及mysql5.1的參考手冊。
    2013-10-10
  • MySQL操作之JSON數據類型操作詳解

    MySQL操作之JSON數據類型操作詳解

    這篇文章主要介紹了MySQL操作之JSON數據類型操作詳解,內容較為詳細,具有收藏價值,需要的朋友可以參考。
    2017-10-10
  • Mysql用戶權限分配實戰(zhàn)項目詳解

    Mysql用戶權限分配實戰(zhàn)項目詳解

    用戶是數據庫的使用者和管理者,MySQL通過用戶的設置來控制數據庫操作人員的訪問與操作范圍,這篇文章主要給大家介紹了關于Mysql用戶權限分配實戰(zhàn)項目的相關資料,需要的朋友可以參考下
    2023-12-12
  • mysql中insert語句的5種用法簡單示例

    mysql中insert語句的5種用法簡單示例

    這篇文章主要給大家介紹了關于mysql中insert語句的5種用法的相關資料,insert into是mysql中最常用的插入語句,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-08-08
  • MySQL之union和union all的使用及區(qū)別說明

    MySQL之union和union all的使用及區(qū)別說明

    這篇文章主要介紹了MySQL之union和union all的使用及區(qū)別說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • mysql中各種常見join連表查詢實例總結

    mysql中各種常見join連表查詢實例總結

    這篇文章主要介紹了mysql中各種常見join連表查詢,結合實例形式總結分析了MySQL中join連表查詢的各種常見用法及相關操作注意事項,需要的朋友可以參考下
    2020-02-02
  • 增刪改查sql語法基礎教程

    增刪改查sql語法基礎教程

    為了準備面試,整理了一些SQL基本語句和自己的理解,作為備份,下面這篇文章主要給大家介紹了關于增刪改查sql語法基礎教程的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-02-02
  • MySQL數據庫分庫分表的方案

    MySQL數據庫分庫分表的方案

    隨著項目不斷迭代,使用人數的不斷增加,數據庫中某些表數據正在逐步膨脹,往單表千萬迅速靠攏,,所以最近也在考慮做一下分庫分表,本文就給大家詳細講解了什么分庫分表和分庫分表的方案,需要的朋友可以參考下
    2023-11-11

最新評論