电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

mysql用戶變量與set語句示例詳解

瀏覽:5日期:2023-10-08 08:05:44
1 用戶變量介紹

用戶變量即用戶自己定義的變量,我們可以給用戶變量分配值,并且可用在任何可以正常使用標量表達式的地方。

引入用戶變量之前我們必須使用set語句或select語句來定義它,然后為它賦一個值,否則變量就只有一個空值。

用戶變量與連接有關(guān)。也就是說,一個客戶端定義的變量不能被其它客戶端看到或使用。當客戶端退出時,該客戶端連接的所有變量將自動釋放。

2 用戶變量定義

set語句可用于向系統(tǒng)變量或用戶變量賦值,針對用戶變量的定義如下:

SET @var_name = expr [, @var_name = expr] ...

也可使用select語句來定義:

SELECT @var_name := expr [, @var_name = expr] ...

用戶變量:以'@'開始,形式為'@var_name',以區(qū)分用戶變量及列名。它可以是任何隨機的,復合的標量表達式,只要其中沒有列指定。

一個變量名可以由當前字符集的數(shù)字字母字符和“_”、“$”和“.”組成。缺省字符集是ISO-8859-1 Latin1;這可以用mysqld 的--default-character-set 選項更改字符集。

對于SET,可以使用=或:=來賦值,對于SELECT只能使用:=來賦值。

我們可以使用一條簡單的select語句查詢定義的用戶變量的值。

3 用戶變量的使用3.1 通過set的實例

用來把一個值賦給一個變量的標量表達式可以是復合表達式。計算,函數(shù),系統(tǒng)標量以及其他用戶變量都是允許的,子查詢也是允許的。然后通過select語句可以獲取一個用戶變量的值,結(jié)果是帶有一行的一個表。

mysql> set @var1=1, @var2=’vartest’, @var3=abs(-2), @var4=(select count(*) from mysql.user);mysql> select @var1, @var2, @var3, @var4;+-------+---------+-------+-------+| @var1 | @var2 | @var3 | @var4 |+-------+---------+-------+-------+| 1 | vartest | 2 | 25 |+-------+---------+-------+-------+

在用來為一個用戶變量賦值的表達式中,也可以指定其它的用戶變量,需要注意的是mysql首先確定所有表達式的值,之后才會把值賦給變量。

例如:

mysql> set @varA = 2;

對于下面兩個例子,varB的值是不同的。

例1:

mysql> set @varA = 3, @varB = @varA;mysql> select @varB;+-------+| @varB |+-------+| 2 |+-------+

例2:

mysql> set @varA = 3; mysql> set @varB = @varA;mysql> select @varB; +-------+| @varB |+-------+| 3 |+-------+

mysql用戶變量與set語句示例詳解

3.2 通過select的實例

相對set語句而言,使用select定義變量,會返回一個表格形式的結(jié)果。

mysql> select @var1:=1, @var2:=’vartest’, @var3:=abs(-2), @var4:=(select count(*) from mysql.user);+----------+------------------+----------------+------------------------------------------+| @var1:=1 | @var2:=’vartest’ | @var3:=abs(-2) | @var4:=(select count(*) from mysql.user) |+----------+------------------+----------------+------------------------------------------+| 1 | vartest | 2 | 25 |+----------+------------------+----------------+------------------------------------------+mysql> select @var1, @var2, @var3, @var4;+-------+---------+-------+-------+| @var1 | @var2 | @var3 | @var4 |+-------+---------+-------+-------+| 1 | vartest | 2 | 25 |+-------+---------+-------+-------++-------+---------+-------+-------+| 1 | vartest | 2 | 25 |+-------+---------+-------+-------+

mysql用戶變量與set語句示例詳解

4 用戶變量注意事項

4.1 用戶變量用在where或having子句中,他們必須首先用另一條語句來定義,如下面例子,初次查詢沒有返回結(jié)果,先定以后在查詢才有輸出。

mysql> select @H:=’localhost’ from mysql.user where host = @H;Empty set (0.00 sec)mysql> select @H:=’localhost’;+-----------------+| @H:=’localhost’ |+-----------------+| localhost |+-----------------+1 row in set (0.00 sec)mysql> select @H:=’localhost’, user from mysql.user where host = @H;+-----------------+-----------------+| @H:=’localhost’ | user |+-----------------+-----------------+| localhost | || localhost | jesse || localhost | local || localhost | root || localhost | user_tab_update |+-----------------+-----------------+

4.2 用戶變量為session級別,當我們關(guān)閉客戶端或退出登錄時用戶變量全部消失。如果想用就保存自定義的變量,需要自行創(chuàng)建一個表,將標量insert到表里。

4.3 用戶變量名對大小寫不敏感。

4.4 未定義的變量初始化是null。

5 補充知識:mysql語句do

在do語句中,使用了一個或多個標量表達式,mysql會一條一條的處理它們,但并不顯示表達式的結(jié)果。例如我們可以調(diào)用函數(shù)執(zhí)行后臺的某些事情,而不需要看到其結(jié)果。

例如:

mysql> do sleep(5);Query OK, 0 rows affected (5.00 sec)總結(jié)

到此這篇關(guān)于mysql用戶變量與set語句的文章就介紹到這了,更多相關(guān)mysql用戶變量與set語句內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

相關(guān)文章:
主站蜘蛛池模板: 过滤器_自清洗过滤器_气体过滤器_苏州华凯过滤技术有限公司 | 水成膜泡沫灭火剂_氟蛋白泡沫液_河南新乡骏华消防科技厂家 | 蓝米云-专注于高性价比香港/美国VPS云服务器及海外公益型免费虚拟主机 | 嘉兴恒升声级计-湖南衡仪声级计-杭州爱华多功能声级计-上海邦沃仪器设备有限公司 | 深圳市人通智能科技有限公司| 齿轮减速机电机一体机_齿轮减速箱加电机一体化-德国BOSERL蜗轮蜗杆减速机电机生产厂家 | 微信小程序定制,广州app公众号商城网站开发公司-广东锋火 | PVC快速门-硬质快速门-洁净室快速门品牌厂家-苏州西朗门业 | 深圳APP开发_手机软件APP定制外包_小程序开发公司-来科信 | 薪动-人力资源公司-灵活用工薪资代发-费用结算-残保金优化-北京秒付科技有限公司 | 轻型地埋电缆故障测试仪,频响法绕组变形测试仪,静荷式卧式拉力试验机-扬州苏电 | 兰州UPS电源,兰州山特UPS-兰州万胜商贸| 南京雕塑制作厂家-不锈钢雕塑制作-玻璃钢雕塑制作-先登雕塑厂 | 沈阳庭院景观设计_私家花园_别墅庭院设计_阳台楼顶花园设计施工公司-【沈阳现代时园艺景观工程有限公司】 | 东莞工厂厂房装修_无尘车间施工_钢结构工程安装-广东集景建筑装饰设计工程有限公司 | 基本型顶空进样器-全自动热脱附解吸仪价格-AutoHS全模式-成都科林分析技术有限公司 | 板材品牌-中国胶合板行业十大品牌-环保板材-上海声达板材 | PE拉伸缠绕膜,拉伸缠绕膜厂家,纳米缠绕膜-山东凯祥包装 | 仿清水混凝土_清水混凝土装修_施工_修饰_保护剂_修补_清水混凝土修复-德州忠岭建筑装饰工程 | 协议书_协议合同格式模板范本大全 | 小港信息港-鹤壁信息港 鹤壁老百姓便民生活信息网站 | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 | 深圳VI设计-画册设计-LOGO设计-包装设计-品牌策划公司-[智睿画册设计公司] | 厌氧反应器,IC厌氧反应器,厌氧三相分离器-山东创博环保科技有限公司 | 便携式XPDM露点仪-在线式防爆露点仪-增强型烟气分析仪-约克仪器 冰雕-冰雪世界-大型冰雕展制作公司-赛北冰雕官网 | 仓储货架_南京货架_钢制托盘_仓储笼_隔离网_环球零件盒_诺力液压车_货架-南京一品仓储设备制造公司 | 震动筛选机|震动分筛机|筛粉机|振筛机|振荡筛-振动筛分设备专业生产厂家高服机械 | OLChemim试剂-ABsciex耗材-广州市自力色谱科仪有限公司 | 五轴加工中心_数控加工中心_铝型材加工中心-罗威斯 | 防爆正压柜厂家_防爆配电箱_防爆控制箱_防爆空调_-盛通防爆 | 钢格板|热镀锌钢格板|钢格栅板|钢格栅|格栅板-安平县昊泽丝网制品有限公司 | 自进式锚杆-自钻式中空注浆锚杆-洛阳恒诺锚固锚杆生产厂家 | 骨灰存放架|骨灰盒寄存架|骨灰架厂家|智慧殡葬|公墓陵园管理系统|网上祭奠|告别厅智能化-厦门慈愿科技 | 破碎机_上海破碎机_破碎机设备_破碎机厂家-上海山卓重工机械有限公司 | 耐磨陶瓷,耐磨陶瓷管道_厂家-淄博拓创陶瓷科技 | 丁基胶边来料加工,医用活塞边角料加工,异戊二烯橡胶边来料加工-河北盛唐橡胶制品有限公司 | 光环国际-新三板公司_股票代码:838504| 圣才学习网-考研考证学习平台,提供万种考研考证电子书、题库、视频课程等考试资料 | 大学食堂装修设计_公司餐厅效果图_工厂食堂改造_迈普装饰 | 3d打印服务,3d打印汽车,三维扫描,硅胶复模,手板,快速模具,深圳市精速三维打印科技有限公司 | 蔬菜配送公司|蔬菜配送中心|食材配送|饭堂配送|食堂配送-首宏公司 |