ABS(x)
創(chuàng)新互聯(lián)公司是一家專業(yè)提供來(lái)賓企業(yè)網(wǎng)站建設(shè),專注與成都網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)、H5開(kāi)發(fā)、小程序制作等業(yè)務(wù)。10年已為來(lái)賓眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站設(shè)計(jì)公司優(yōu)惠進(jìn)行中。
【功能】返回x的絕對(duì)值
【參數(shù)】x,數(shù)字型表達(dá)式
【返回】數(shù)字
【示例】
select abs(100),abs(-100) from dual;
格式:abs(number) ?即 ?abs(數(shù)值)
返回?cái)?shù)值的絕對(duì)值。
例: ?abs(5) ? 返回 5
abs(-5) ? 返回 5
Oracle SQL 提供了用于執(zhí)行特定操作的專用函數(shù)。這些函數(shù)大大增強(qiáng)了 SQL 語(yǔ)言的功能。函數(shù)可以接受零個(gè)或者多個(gè)輸入?yún)?shù),并返回一個(gè)輸出結(jié)果。 oracle 數(shù)據(jù)庫(kù)中主要使用兩種類型的函數(shù):
單行函數(shù):對(duì)每一個(gè)函數(shù)應(yīng)用在表的記錄中時(shí),只能輸入一行結(jié)果,返回一個(gè)結(jié)果。
聚合函數(shù):聚合函數(shù)同時(shí)可以對(duì)多行數(shù)據(jù)進(jìn)行操作,并返回一個(gè)結(jié)果。比如 SUM(x)
返回結(jié)果集中 x 列的總合。
1.字符串函數(shù)
char_lengt()
concat()
instr()
lcase()
left()
ltrim()
mid()
2.時(shí)間函數(shù)
now()
curdate()
curtime()
datediff()
date_add()
數(shù)學(xué)函數(shù)
abs()
ceiling()
floor()
pow()
rand()
round()
其他函數(shù)
md5()
version()
database()
UUID()
同一使用select 函數(shù)名(參數(shù)列表)
背景
在上一篇推文中,我們介紹了 MySQL Group Replication 8.0.16 支持信息碎片化功能來(lái)增強(qiáng)大型事務(wù)處理能力。
如果您想在組復(fù)制中使用該功能,則任何組成員的版本都不能低于 8.0.16!
簡(jiǎn)單地說(shuō)就是由于低版本協(xié)議上不支持。MySQL 8.0.16 的組通訊開(kāi)始支持新協(xié)議,簡(jiǎn)稱“分段協(xié)議”,之前的版本中只有一種“壓縮協(xié)議”。
如果多個(gè)成員想加入復(fù)制組,那么在協(xié)議匹配上遵循以下原則:
現(xiàn)有復(fù)制組成員和新加入成員版本相同,加入成功。
低版本成員想加入高版本的組會(huì)被驅(qū)逐,加入失敗。
高版本的成員想加入低版本的組,單獨(dú)加入成功,多個(gè)加入失敗。
例如:
一個(gè) MySQL Server 8.0.16 實(shí)例可以成功加入使用通信協(xié)議版本 5.7.24 的組。
一個(gè) MySQL Server 5.7.24 實(shí)例無(wú)法成功加入使用通信協(xié)議版本 8.0.16 的組。
兩個(gè) MySQL Server 8.0.16 實(shí)例無(wú)法同時(shí)加入使用通信協(xié)議版本 5.7.24 的組。
兩個(gè) MySQL Server 8.0.16 實(shí)例可以同時(shí)加入使用通信協(xié)議版本 8.0.16 的組。
新增 UDF
為了能讓高版本的復(fù)制組更便于加入低版本的成員,MySQL 8.0.16 新增兩個(gè) UDF。
您可以使用兩個(gè)新的 UDF 命令去管理組通信協(xié)議:
1. group_replication_set_communication_protocol(new_protocol)
設(shè)置組復(fù)制通訊協(xié)議版本
SELECT group_replication_set_communication_protocol("8.0.15");
填入一個(gè)所有成員都支持的版本號(hào),即:new_protocol ≤ 所有成員的 MySQL版本。
new_protocol 格式:major.minor.patch (主版本號(hào).次版本號(hào).發(fā)布版本號(hào))例如:8.0.15。
2. group_replication_get_communication_protocol()
獲取復(fù)制中最舊成員的 MySQL 版本號(hào)
SELECT group_replication_get_communication_protocol(); ? ?+------------------------------------------------+ ? ?| group_replication_get_communication_protocol() | ? ?+------------------------------------------------+ ? ?| 5.7.14 ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? | ? ?+------------------------------------------------+
獲取的版本號(hào)可能與設(shè)置的值不一致,但不一致的版本之間組復(fù)制協(xié)議是一樣的。
返回結(jié)果格式:major.minor.patch (主版本號(hào).次版本號(hào).發(fā)布版本號(hào))例如:8.0.15。
以上兩個(gè) UDF 對(duì)全部組成員有效,主機(jī)或從機(jī)上均可執(zhí)行。
結(jié)論
若想使用信息碎片功能。建議將組復(fù)制成員全部升級(jí)為 8.0.16。
若組內(nèi)成員版本僅有部分為 8.0.16,可以用兩個(gè)新的函數(shù)來(lái)讓高版本的成員保持與其它成員組協(xié)議一致。
請(qǐng)點(diǎn)擊輸入圖片描述
這是很久之前的就遇到的問(wèn)題了,去年寫了個(gè)WP插件:WordPress投票插件Ludou
Simple
Vote,由于有些使用者需要一個(gè)投票排行榜,所以需要用一條SQL來(lái)讀取按得分排序的文章列表。
Ludou
Simple
Vote的投票得分結(jié)果是以自定義欄目的方式存儲(chǔ)在WordPress的postmeta中,分值存放在meta_value字段,而meta_value字段類型是longtext,如果直接使用下面的SQL查詢語(yǔ)句來(lái)排序:
復(fù)制代碼
代碼如下:
ORDER
BY
`meta_value`
那么按得分排序得到的結(jié)果可能是:
1
10
11
123
1234
2
25
253
3
由于是按字母順序排列,所以123排在了2的前面,顯然不符合我們的要求,那么怎樣才能按照我們預(yù)想的數(shù)字順序排序呢?下面介紹兩種方法。
一、采用MySQL的cast函數(shù),轉(zhuǎn)換字段格式
這里我們將meta_value字段轉(zhuǎn)換成數(shù)值類型的字段DECIMAL,然后再進(jìn)行排序:
復(fù)制代碼
代碼如下:
ORDER
BY
CAST(`meta_value`
AS
DECIMAL)
需要注意的是,你所要排序的meta_value字段的值必須都是可轉(zhuǎn)換成數(shù)字,否則將會(huì)出錯(cuò)。
二、使用MySQL絕對(duì)值函數(shù)ABS
使用MySQL絕對(duì)值函數(shù)ABS,它告訴MySQL使用絕對(duì)值來(lái)處理處理這個(gè)字段:
復(fù)制代碼
代碼如下:ORDER
BY
ABS(`meta_value`)