MySQL 數據庫(基礎)- 函數

MySQL 數據庫(基礎)- 函數

介紹

函數 是指一段可以被另一段程序調用的程序或代碼。也意味著,這一段程序或代碼在 MySQL 中已經給我們提供了,我們需要做的就是在合適的業務場景調用對應的函數,完成對應的業務需求即可。

MySQL 中的函數主要分為一下四類:字符串函數,數值函數,日期函數,流程函數。

  1. 字符串函數
    MySQL 中提供了很多的字符串函數,常用的幾個如下:
函數							功能
concat(s1,s2,....sn)		字符串拼接,將S1,S2,... Sn拼接成一個字符串
lower(str)					將字符串str全部轉為小寫
upper(str)					將字符串str全部轉為大寫
lpad(str,n,pad)				左填充,用字符串pad對str的左邊進行填充,達到n個字符串長度
rpad(str,n,pad)				右填充,用字符串pad對str的右邊進行填充,達到n個字符串長度
trim(str)					去掉字符串頭部和尾部的空格
substring(str,start,len)	返回從字符串str從start位置起的len個長度的字符串

演示代碼:

  • concat : 字符串拼接
select concat('Hello' , ' MySQL'); 
  • lower : 全部轉小寫
select lower('Hello');
  • upper : 全部轉大寫
select upper('Hello');
  • lpad : 左填充
select lpad('01', 5, '-');
  • rpad : 右填充
select rpad('01', 5, '-');
  • trim : 去除空格
select trim(' Hello MySQL ');
  • substring : 截取子字符串
select substring('Hello MySQL',1,5);
  1. 數值函數
    常見的數值函數如下:
函數							功能
ceil(x)						向上取整
floor(x)					向下取整
mod(x,y)					返回x/y的模
rand()						返回0~1內的隨機數
round(x,y)					求參數x的四舍五入的值,保留y位小數

演示代碼:

  • ceil:向上取整
select ceil(1.1);
  • floor:向下取整
select floor(1.9);
  • mod:取模
select mod(7,4);
  • rand:獲取隨機數
select rand();
  • round:四舍五入
select round(2.344,2);
  1. 日期函數
    常見的日期函數如下:
函數											功能
curdate()									返回當前日期
curtime()									返回當前時間
now()										返回當前日期和時間
year(date)									獲取指定date的年份
month(date)									獲取指定date的月份
day(date)									獲取指定date的日期
date_add(date,interval exprtype)			返回一個日期/時間值加上一個時間間隔expr后的時間值
datediff(date1,date2)						返回起始時間date1 和 結束時間date2之間的天數

演示代碼:

  • curdate:當前日期
select curdate();
  • curtime:當前時間
select curtime();
  • now:當前日期和時間
select now();
  • YEAR , MONTH , DAY:當前年、月、日
select YEAR(now());
select MONTH(now());
select DAY(now());
  • date_add:增加指定的時間間隔
select date_add(now(), INTERVAL 70 YEAR );
  • datediff:獲取兩個日期相差的天數
select datediff('2021-10-01', '2021-12-01');
  1. 流程函數
    流程函數也是很常用的一類函數,可以在 SQL 語句中實現條件篩選,從而提高語句的效率。
函數																功能
if(value,t,f)													如果valuetrue,則返回t,否則返回f
ifnull(value1,value2)											如果value1不為空,返回value1,否則返回value2
case when [vall] then [res1] ... eles [default] end				如果val1為true,返回res1,... 否則返回default默認值
case [expr] when [vall] then [res1] ... else [default] end		如果expr的值等于val1,返回res1,... 否則返回default默認值

演示代碼:

  • if
select if(false, 'Ok', 'Error');
  • ifnull
select ifnull('Ok','Default');
select ifnull('','Default');
select ifnull(null,'Default');
  • case when then else end
    需求: 查詢emp表的員工姓名和工作地址 (北京/上海 ----> 一線城市 , 其他 ----> 二線城市)
select
name,
( case workaddress when '北京' then '一線城市' when '上海' then '一線城市' else
'二線城市' end ) as '工作地址'
from emp;

案例:

create table score(id int comment 'ID',name varchar(20) comment '姓名',math int comment '數學',english int comment '英語',chinese int comment '語文'
) comment '學員成績表';insert into score(id, name, math, english, chinese) VALUES (1, 'Tom', 67, 88, 95
), (2, 'Rose' , 23, 66, 90),(3, 'Jack', 56, 98, 76);

具體的SQL語句如下:

select
id,
name,
(case when math >= 85 then '優秀' when math >=60 then '及格' else '不及格' end )
'數學',
(case when english >= 85 then '優秀' when english >=60 then '及格' else '不及格'
end ) '英語',
(case when chinese >= 85 then '優秀' when chinese >=60 then '及格' else '不及格'
end ) '語文'
from score;

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/44555.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/44555.shtml
英文地址,請注明出處:http://en.pswp.cn/web/44555.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

python的簡單爬取

需要的第三方模塊 requests winr打開命令行輸入cmd 簡單爬取的基本格式(爬取百度logo為例) import requests url"http://www.baidu.com/img/PCtm_d9c8750bed0b3c7d089fa7d55720d6cf.png" resprequests.get(url)#回應 #保存到本地 with open(&…

中國物流信息軟件系統(WMS等)行業概覽,2027年將達到235.1億元

導語 大家好,我是社長,老K。專注分享智能制造和智能倉儲物流等內容。 新書《智能物流系統構成與技術實踐》人俱樂部 完整版文件和更多學習資料,請球友到知識星球【智能倉儲物流技術研習社】自行下載 這份文件是《2023年中國物流信息軟件系統行…

【Python】下載與安裝

目錄 一、 下載安裝Python 1. 配置環境變量 2. 檢查是否配置成功 一、 下載安裝Python 在我上傳的資源可以免費下載!!! https://download.csdn.net/download/m0_67830223/89536665?spm1001.2014.3001.5501https://download.csdn.net/dow…

淺談后置處理器之JSON提取器

淺談后置處理器之JSON提取器 JMeter 的 JSON 提取器(JSON Extractor)是一個強大的后置處理器,它允許用戶從HTTP響應、數據庫查詢或其他類型的響應中提取JSON數據,并將這些數據存儲為變量,以便在后續的請求中重用。這對…

Mojo AI編程語言(三)數據結構:高效數據處理

目錄 1. Mojo AI編程語言簡介 2. 數據結構在數據處理中的重要性 3. Mojo AI中的基礎數據結構 3.1 數組 3.2 列表 3.3 字典 4. 高效數據結構的實現與優化 4.1 哈希表 4.2 樹結構 4.3 圖結構 5. 高效數據處理技術 5.1 并行處理 5.2 內存優化 5.3 數據壓縮 6. 實戰…

【Redis】哨兵(sentinel)

文章目錄 一、哨兵是什么?二、 哨兵sentinel文件參數三、 模仿主機redis宕機四、哨兵運行流程和選舉原理SDOWN主觀下線ODOWN客觀下線 五、 使用建議 以下是本篇文章正文內容 一、哨兵是什么? 哨兵巡查監控后臺master主機是否故障,如果故障了…

js項目生產環境中移除 console

1、terser-webpack-plugin webpack 構建的項目中安裝使用 安裝: npm install terser-webpack-plugin --save-dev 配置 在webpack.config.js文件中 new TerserPlugin({terserOptions: {output: {comments: false, // 去除注釋},warnings: false, // 去除黃色警告,co…

nx上darknet的使用-目標檢測-自定義訓練與制作預訓練模型

目錄 1 訓練yolov4-tiny 1.1 文件準備 1.1.1 Annotations 1.1.2 JPEGImages 1.1.3 labels 1.1.4 trained_models 1.1.5 classes.name 1.1.6 create_labels_txt.py 1.1.7 custom_training.data 1.1.8 get_labels.py 1.1.9 get_train_val.py 1.1.10 train…

python制作甘特圖的基本知識(附Demo)

目錄 前言1. matplotlib2. plotly 前言 甘特圖是一種常見的項目管理工具,用于表示項目任務的時間進度 直觀地看到項目的各個任務在時間上的分布和進度 常用的繪制甘特圖的工具是 matplotlib 和 plotly 主要以Demo的形式展示 1. matplotlib 功能強大的繪圖庫&a…

內網對抗-基石框架篇單域架構域內應用控制成員組成用戶策略信息收集環境搭建

知識點: 1、基石框架篇-單域架構-權限控制-用戶和網絡 2、基石框架篇-單域架構-環境搭建-準備和加入 3、基石框架篇-單域架構-信息收集-手工和工具1、工作組(局域網) 將不同的計算機按照功能分別列入不同的工作組。想要訪問某個部門的資源,只要在“網絡…

Electron運行報錯:Error Cannot find module ‘node_moduleselectroncli.js‘

Electron運行報錯:Error: Cannot find module ‘node_modules\electron\cli.js’ 顧名思義,命令行執行Electron .時候,會優先從項目目錄查找對應依賴,如果是報錯顯示是找不到項目目錄下的依賴,我們可以從安裝在全局的…

DAMA學習筆記(五)-數據存儲和操作

1.引言 數據存儲與操作包括對存儲數據的設計、實施和支持,最大化實現數據資源的價值,貫穿于數據創建/獲取到處置的整個生命周期。 數據存儲與操作包含兩個子活動(圖6-1)。 圖6-1 語境關系圖:數據存儲與操作 (1) 數據庫…

記錄vite項目中Cornerstone的兼容問題(持續更新)

🔎 在vite項目中打包提示錯誤 ESM integration proposal for Wasm" is not supported currently. ?? 問題描述 Error: Could not load /home/xxx/xxx/node_modules/icr/polyseg-wasm/dist/ICRPolySeg.wasm (imported by node_modules/icr/polyseg-wasm/di…

js ES6 part3

Number 是內置構造函數&#xff0c;用來創建數值 const price 12.345console.log(price.toFixed(2))//保留兩位小數 12.35 綜合案例購物車 <body><div class"list"><!-- <div class"item"><img src"https://yanxuan-item…

【代碼隨想錄】【算法訓練營】【第66天】 [卡碼95]城市間貨物運輸II [卡碼96]城市間貨物運輸III

前言 思路及算法思維&#xff0c;指路 代碼隨想錄。 題目來自 卡碼網。 day 66&#xff0c;周五&#xff0c;ding ding~ [卡碼95] 城市間貨物運輸II 題目描述 卡碼95 城市間貨物運輸II 解題思路 前提&#xff1a; 思路&#xff1a; 重點&#xff1a; 代碼實現 C語言 …

數據結構(Java):隊列Queue集合力扣面試OJ題

1、隊列 1.1 隊列的概念 隊列是一個特殊的線性表&#xff0c;只允許在一端&#xff08;隊尾&#xff09;進行插入數據操作&#xff0c;在另一端&#xff08;對頭&#xff09;進行刪除數據。隊列具有先進先出FIFO(First In First Out)的特性。 入隊&#xff1a;數據只能從隊尾…

有獎競猜!斗牛士軍團與法蘭西騎士的終極之戰,誰將笑傲歐洲之巔?

痛快看球&#xff0c;暢玩游戲&#xff0c;AGON愛攻帶你進入酣暢淋漓的足球世界&#xff01; 7月15日&#xff0c;綠茵賽場硝煙再起&#xff0c;兩支身披榮光的王者之師&#xff0c;一路過關斬將&#xff0c;最終會師決賽。一場萬眾矚目的巔峰對決即將拉開帷幕&#xff0c;究竟…

linux UDP通訊:接口函數示例

一、主要用的接口&#xff1a; //服務器端 1. socket() 創建套接字 2. bind() 綁定套接字 與TCP區別開來&#xff0c;沒有listen()、accept()建立連接的過程 3. 通信 recvfrom() sendto() 4. close //客戶端 1. socket() 創建套接字 與TCP區別開來&#xff0c;沒有connect()建立…

數據結構——排序算法(冒泡、快速、選擇、插入)

文章目錄 1. 概念 2. 十大排序算法 3. 冒泡排序 4. 冒泡代碼實現 5. 快速排序 6. 快速代碼實現 7. 選擇排序 8. 選擇代碼實現 9. 插入排序 10. 插入代碼實現 1. 概念 排序&#xff08;Sort&#xff09;是將無序的記錄序列&#xff08;或稱文件&#xff09;調整成有序…

LabVIEW前面板占滿整個屏幕(轉)

希望在運行一個LabVIEW程序時&#xff0c;它的前面板能夠占據整個屏幕&#xff0c;且不顯示Windows的任務欄或其他任何的LabVIEW菜單選項。怎樣才能實現這一功能&#xff1f; 您可以通過手動配置或編程的方式實現該功能。 手動配置VI屬性 您可以通過以下操作&#xff0c;將…