MySql變數說明

来源:https://www.cnblogs.com/deyo/archive/2020/07/24/13371137.html
-Advertisement-
Play Games

1 #變數 2 /* 3 系統變數: 4 全局變數 5 會話變數 6 7 自定義變數: 8 用戶變數 9 局部變數 10 11 */ 12 #一、系統變數 13 /* 14 說明:變數由系統定義,不是用戶定義,屬於伺服器層面 15 註意:全局變數需要添加global關鍵字,會話變數需要添加sessi ...


  1 #變數
  2 /*
  3 系統變數:
  4     全局變數
  5     會話變數
  6 
  7 自定義變數:
  8     用戶變數
  9     局部變數
 10 
 11 */
 12 #一、系統變數
 13 /*
 14 說明:變數由系統定義,不是用戶定義,屬於伺服器層面
 15 註意:全局變數需要添加global關鍵字,會話變數需要添加session關鍵字,如果不寫,預設會話級別
 16 使用步驟:
 17 1、查看所有系統變數
 18 show global|【session】variables;
 19 2、查看滿足條件的部分系統變數
 20 show global|【session】 variables like '%char%';
 21 3、查看指定的系統變數的值
 22 select @@global|【session】系統變數名;
 23 4、為某個系統變數賦值
 24 方式一:
 25 set global|【session】系統變數名=值;
 26 方式二:
 27 set @@global|【session】系統變數名=值;
 28 
 29 */
 30 #1》全局變數
 31 /*
 32 作用域:針對於所有會話(連接)有效,但不能跨重啟
 33 */
 34 #①查看所有全局變數
 35 SHOW GLOBAL VARIABLES;
 36 #②查看滿足條件的部分系統變數
 37 SHOW GLOBAL VARIABLES LIKE '%char%';
 38 #③查看指定的系統變數的值
 39 SELECT @@global.autocommit;
 40 #④為某個系統變數賦值
 41 SET @@global.autocommit=0;
 42 SET GLOBAL autocommit=0;
 43 
 44 #2》會話變數
 45 /*
 46 作用域:針對於當前會話(連接)有效
 47 */
 48 #①查看所有會話變數
 49 SHOW SESSION VARIABLES;
 50 #②查看滿足條件的部分會話變數
 51 SHOW SESSION VARIABLES LIKE '%char%';
 52 #③查看指定的會話變數的值
 53 SELECT @@autocommit;
 54 SELECT @@session.tx_isolation;
 55 #④為某個會話變數賦值
 56 SET @@session.tx_isolation='read-uncommitted';
 57 SET SESSION tx_isolation='read-committed';
 58 
 59 #二、自定義變數
 60 /*
 61 說明:變數由用戶自定義,而不是系統提供的
 62 使用步驟:
 63 1、聲明
 64 2、賦值
 65 3、使用(查看、比較、運算等)
 66 */
 67 
 68 #1》用戶變數
 69 /*
 70 作用域:針對於當前會話(連接)有效,作用域同於會話變數
 71 */
 72 
 73 #賦值操作符:=或:=
 74 #①聲明並初始化
 75 SET @變數名=值;
 76 SET @變數名:=值;
 77 SELECT @變數名:=值;
 78 
 79 #②賦值(更新變數的值)
 80 #方式一:
 81     SET @變數名=值;
 82     SET @變數名:=值;
 83     SELECT @變數名:=值;
 84 #方式二:
 85     SELECT 欄位 INTO @變數名
 86     FROM 表;
 87 #③使用(查看變數的值)
 88 SELECT @變數名;
 89 
 90 
 91 #2》局部變數
 92 /*
 93 作用域:僅僅在定義它的begin end塊中有效
 94 應用在 begin end中的第一句話
 95 */
 96 
 97 #①聲明
 98 DECLARE 變數名 類型;
 99 DECLARE 變數名 類型 【DEFAULT 值】;
100 
101 
102 #②賦值(更新變數的值)
103 
104 #方式一:
105     SET 局部變數名=值;
106     SET 局部變數名:=值;
107     SELECT 局部變數名:=值;
108 #方式二:
109     SELECT 欄位 INTO 具備變數名
110     FROM 表;
111 #③使用(查看變數的值)
112 SELECT 局部變數名;
113 
114 
115 #案例:聲明兩個變數,求和並列印
116 
117 #用戶變數
118 SET @m=1;
119 SET @n=1;
120 SET @sum=@m+@n;
121 SELECT @sum;
122 
123 #局部變數
124 DECLARE m INT DEFAULT 1;
125 DECLARE n INT DEFAULT 1;
126 DECLARE SUM INT;
127 SET SUM=m+n;
128 SELECT SUM;
129 
130 
131 #用戶變數和局部變數的對比
132 
133         作用域            定義位置        語法
134 用戶變數    當前會話        會話的任何地方        加@符號,不用指定類型
135 局部變數    定義它的BEGIN END中     BEGIN END的第一句話    一般不用加@,需要指定類型
136             

 


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

-Advertisement-
Play Games
更多相關文章
  • SQL 庫結構操作SQL 1、查看所有資料庫 show databases; 2、切換使用資料庫 use 資料庫名; 3、創建資料庫 create database 資料庫名; create database 資料庫名 charset 'utf8'; 4、刪除資料庫 drop database 數據 ...
  • 軟體下載地址:https://www.mongodb.com/try/download/community 提供了二進位執行版,不需要make安裝,將解壓好的內容,直接移動到軟體安裝目錄即可。 在軟體安裝目錄(/usr/local/src)下創建一個名為mongodb的軟連接 ln -s mongo ...
  • 資料庫 多個集合可以組成資料庫。一個MongoDB實例可以承載多個資料庫,他們之間完全獨立。 MongoDB中的資料庫和MySQL中的資料庫概念類似,只是無需創建。 一個資料庫中可以有多個集合,一個集合中可以有多個文檔。 集合 集合就是一組文檔,多個文檔組成一個集合,集合類似於MySQL裡面的表。 ...
  • 基本簡介 MongoDB是一個介於關係資料庫和非關係資料庫之間的產品,是非關係資料庫當中功能最豐富,最像關係資料庫的,語法有點類型javascript面向對象的查詢語言,它是一個買你想幾核的,模式自由的文檔型資料庫。實現類似關係資料庫單表查詢的絕大部門功能,而且還支持對資料庫建立素偶姻。它的特點是高 ...
  • -- 危險操作,處理前記得先備份資料庫 1 declare @sql varchar(500),@tbname varchar(100) 2 begin 3 4 -- 創建游標 5 declare cursor_item cursor fast_forward for select [name] f ...
  • 當我們剛開始接觸一些已經成型的項目時,不複雜還好,複雜的話,比如說ERP項目,其中業務邏輯複雜可能會各種存儲過程之間來回調用,我們可以用 --查詢哪裡調用該表或存儲過程 select distinct object_name(id) from syscomments where id in (sel ...
  • 想把mlsql卸載了重裝,看了許多文章試了很多方法都沒辦法完全卸載,直到看到了這篇文章, 可以完全卸載mysql,在這裡謝謝博主,也拿出來分享給大家 原文鏈接:https://blog.csdn.net/qq_41140741/article/details/81489531 快捷鍵win+r輸入r ...
  • 這三個對象都可以實現自增,這裡從如下幾個維度來看看這幾個對象有哪些不同,其中功能性上看,大部分特性都是一致的或者類似的。 1,sequence在所有資料庫中的性質都一樣,它是跟具體的欄位不是強綁定的,其特點是支持多個對個對象之間共用。 sequence作為自增欄位值的時候,對錶的寫入需要另外單獨授權 ...
一周排行
    -Advertisement-
    Play Games
  • 一、引言:什麼是 JSON JSON (Java Script Object Notation) 是一種很常用的數據格式,它常常用在 web 應用程式中。它可以表示結構化的數據。 下麵是常見的 JSON 文件結構 { "name": "Kamishiro Rize", "age": "22", "o ...
  • 前言 大家好,我是蝸牛,在上一篇中,我們介紹了不同版本的HTTP區別和發展背景,這篇文章我們來聊聊HTTP的缺點,HTTP缺點大致總結有以下三點: 通信使用明文(不加密),內容可能會被竊聽。 不驗證通信方的身份,因此有可能遭遇偽裝(客戶端和服務端都有可能) 無法證明報文的完整性,有可能會被篡改。 其 ...
  • resultMap處理欄位和屬性的映射關係 如果欄位名與實體類中的屬性名不一致,該如何處理映射關係? 第一種方法:為查詢的欄位設置別名,和屬性名保持一致 下麵是實體類中的屬性名: private Integer empId; private String empName; private Integ ...
  • 大家在看到這篇文章前,為了有一個舒適的c++IDE,一定感受到了Dev-c++的廉價感,Clion功能的多餘,VS的臃腫。他們也有自己的優點,但糟點太多,令人十分難受。而VS Code,可以取長補短。下麵的配置內容,可以讓你在刷題時,享受絲滑的動畫,體會集成終端的方便,讓你覺得Coding不再枯燥。 ...
  • 給定一個不含重覆數字的數組 nums ,返回其 所有可能的全排列 。你可以 按任意順序 返回答案。 示例 1: 輸入:nums = [1,2,3] 輸出:[[1,2,3],[1,3,2],[2,1,3],[2,3,1],[3,1,2],[3,2,1]] 示例 2: 輸入:nums = [0,1] 輸 ...
  • 設計模式的目的 編寫軟體過程中,程式員面臨著來自 耦合性,內聚性以及可維護性,可擴展性,重用性,靈活性 等多方面的 挑戰,設計模式是為了讓程式(軟體),具有更好 代碼重用性 (即:相同功能的代碼,不用多次編寫) 可讀性 (即:編程規範性, 便於其他程式員的閱讀和理解) 可擴展性 (即:當需要增加新的 ...
  • 本文講解了決策樹的創鍵的過程,包括熵,信息增益的計算,還有決策樹的創建,以及使用matplotlib讓決策樹可視化的詳細過程 ...
  • ♠ use C++11 倍數 若 $a,b,k \in \mathbb N$,且 $a \times k=b$,那麼 $b$ 是 $a$ 的倍數,稱 $a$ 整除 $b$,記作 $a \mid b$。 $[1,n]\in \mathbb N$ 中 $x \in \mathbb N$ 的倍數有 $\l ...
  • LinkList可以定義指向List的指針 1.當函數參數為LinkList L時,意味著只改變或操作List的內容,而不需要改變L這個指針 如 Status GetElem(LinkList L,int i,ElemType) 2.當參數為LinkList &L時,意味著需要改變或操作L這個指針本 ...
  • Spring 5框架 一、Spring概念 1、Spring是輕量級的JavaEE框架 2、Spring可以解決企業應用開發的複雜性 3、Spring有兩個核心部分:IOC和AOP ​ 1)IOC:控制反轉,把創建對象過程交給Spring進行管理 ​ 2)AOP:面向切麵,不修改源代碼進行功能增強 ...