婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識(shí)庫 > MySQL 自定義變量的概念及特點(diǎn)

MySQL 自定義變量的概念及特點(diǎn)

熱門標(biāo)簽:400電話辦理服務(wù)價(jià)格最實(shí)惠 武漢電銷機(jī)器人電話 催天下外呼系統(tǒng) 大豐地圖標(biāo)注app html地圖標(biāo)注并導(dǎo)航 南太平洋地圖標(biāo)注 400電話變更申請 北京金倫外呼系統(tǒng) 呂梁外呼系統(tǒng)

MySQL 的自定義 就是存儲(chǔ)值的臨時(shí)容器,只要與服務(wù)端的連接是活躍的,容器中的值可以保存和使用。可以通過簡單的 SET 或 SELECT語句 設(shè)置自定義變量,如下所示:

SET @one := 1;
SET @min_actor := (SELECT MIN(actor_id) FROM sakila.actor);
SET @last_week := CURRENT_DATE-INTERNAL 1 WEEK;

定義好變量后,就可以在 SQL 語句中使用這個(gè)變量:

SELECT * FROM film WHERE created_date = @last_week;

雖然 MySQL 自定義變量很強(qiáng)大,但是也需要知道自定義變量本身也是有缺陷的,這些缺陷包括:

  • 自定義變量會(huì)禁用查詢緩存。
  • 不可以用做替代語義上的標(biāo)識(shí)符,例如表名稱或列名稱,或者是在 LIMIT 子句中使用。
  • 自定義變量是基于單次連接的,因此不可以跨連接使用。
  • 如果使用連接池或持久連接,自定義變量會(huì)導(dǎo)致你的代碼與交互隔離,這出現(xiàn)的時(shí)候可能是代碼的 bug 或連接池的 bug,但是是可能發(fā)生的。
  • 在 MySQL 5.0以前的版本中是大小寫敏感的,因此要注意(在 MySQL 5.0以后已經(jīng)不區(qū)分大小寫了)。
  • 無法顯示地指定變量類型,而實(shí)際變量的類型依賴于不確定的類型推斷,并且不同的版本會(huì)有差異,最好的方式是在一開始定義的時(shí)候指定類型,比如使用0設(shè)定整數(shù)變量,0.0設(shè)定浮點(diǎn)數(shù)變量,''用于字符串。但是如果后面指定了新的值,類型會(huì)跟隨新的值改變,這是因?yàn)?MySQL 的自定義變量的類型是動(dòng)態(tài)的。
  • 優(yōu)化器在某些情況下有可能會(huì)將自定義變量優(yōu)化掉,導(dǎo)致無法按照期望的方式進(jìn)行查詢。
  • 賦值的次序,甚至包括賦值的時(shí)間都是不確定的,這取決于優(yōu)化器選擇的查詢計(jì)劃。因此,最終的結(jié)果可能讓人困惑。
  • 賦值操作符的優(yōu)先級(jí)低于任何其他操作符,因此必須顯示地使用括號(hào)。
  • 未定義變量不會(huì)報(bào)錯(cuò),這很容導(dǎo)致錯(cuò)誤出現(xiàn)。

自定義變量可以用在所有類型的語句中,而不僅僅是 SELECT 語句。事實(shí)上,這是自定義變量的一個(gè)最大的優(yōu)勢。例如,我們可以重寫復(fù)雜的查詢,例如利用子查詢進(jìn)行排序的計(jì)算,或者是完成一次低代價(jià)的UPDATE 語句。

有些時(shí)候,優(yōu)化器會(huì)認(rèn)為這個(gè)變量是編譯時(shí)常量而不進(jìn)行賦值,這會(huì)導(dǎo)致期望的行為很怪異。而將自定義變量的賦值放入類似 LEAST函數(shù)中通常會(huì)避免這個(gè)問題。另一個(gè)方式是在使用之前檢查一下自定義變量是否有值。有時(shí)候你想這樣做,但有些時(shí)候你不想這么做。

通過一些小的實(shí)驗(yàn),我們可以使用自定義變量做很多有趣的事情,例如:

  • 計(jì)算總量和平均值;
  • 對于分組查詢模擬 FIRST 和 LAST 函數(shù);
  • 對于很大的數(shù)做數(shù)學(xué)運(yùn)算;
  • 將一整張表轉(zhuǎn)換成 MD5哈希值;
  • 過濾掉0值附近但超過設(shè)定邊界的樣本值;
  • 模擬讀寫指針位置;
  • 將變量嵌入到 WHERE 條件并在 SHOW 語句中顯示。

自定義變量在某些應(yīng)用場合很有用,例如統(tǒng)計(jì)出現(xiàn)次數(shù)的排序值,計(jì)算更新和插入相同數(shù)據(jù)的次數(shù),以及延遲的聯(lián)合查詢,下一篇文章將介紹具體的用法。

以上就是MySQL 的自定義變量的概念及特點(diǎn)的詳細(xì)內(nèi)容,更多關(guān)于MySQL 自定義變量的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • MySQL中使用自定義變量 編寫偷懶的UNION示例
  • 理解MySQL查詢優(yōu)化處理過程
  • mysql查詢優(yōu)化之100萬條數(shù)據(jù)的一張表優(yōu)化方案
  • 詳解MySQL 聯(lián)合查詢優(yōu)化機(jī)制
  • MySQL查詢優(yōu)化之查詢慢原因和解決技巧
  • MySQL之select in 子查詢優(yōu)化的實(shí)現(xiàn)
  • Mysql慢查詢優(yōu)化方法及優(yōu)化原則
  • 30個(gè)mysql千萬級(jí)大數(shù)據(jù)SQL查詢優(yōu)化技巧詳解
  • mysql大數(shù)據(jù)查詢優(yōu)化經(jīng)驗(yàn)分享(推薦)
  • MySQL百萬級(jí)數(shù)據(jù)分頁查詢優(yōu)化方案
  • MySQL 使用自定義變量進(jìn)行查詢優(yōu)化

標(biāo)簽:迪慶 南充 徐州 自貢 西寧 龍巖 麗水 無錫

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL 自定義變量的概念及特點(diǎn)》,本文關(guān)鍵詞  MySQL,自定義,變量,的,概,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL 自定義變量的概念及特點(diǎn)》相關(guān)的同類信息!
  • 本頁收集關(guān)于MySQL 自定義變量的概念及特點(diǎn)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 拜泉县| 柘城县| 宿松县| 琼结县| 东台市| 光泽县| 石台县| 浑源县| 页游| 黑山县| 林周县| 广宁县| 江孜县| 原阳县| 府谷县| 沾益县| 五寨县| 岳阳县| 盱眙县| 江源县| 五华县| 宿松县| 桑日县| 启东市| 富顺县| 酉阳| 襄垣县| 镇雄县| 卓尼县| 安仁县| 梅州市| 都兰县| 石首市| 桂阳县| 白山市| 固阳县| 和硕县| 鹤峰县| 东乡县| 元阳县| 高清|