mysql存储过程及常用函数_MySQL
一.函数
1.数学函数
CEIL()进一取整
SELECT CEIL(1.2);2
FLOOR()舍一取整
SELECT FLOOR(1.9);9
MOD取余数(取模)
SELECT MOD(3,8);3--3对8取模
POWER()幂运算
SELECT POWER(3,2);9
ROUND()四舍五入
SELECT ROUND(123.456,2);123.46
TRUNCTATE数字截取
SELECT TRUNCATE(123.456,2);123.45
ABS()取绝对值
SELECT ABS(-123);123
PI()圆周率
SELECT PI();3.14
RAND()和RAND(X)
SELECT RAND();0到1之间的一个随机数
SELECT RAND(2);0到1之间的一个随机数
ORDER BY RAND();按随机排序
SIGN(X)得到数值符合正数0和负数1
EXP(X)e的X方
2.字符串函数
LENGTH返回字符串长度
SELECT LENGTH('KAIKEBA');7
SELECT LENGTH('开课吧');6
CHAR_LENGTH返回字符串的字符数
SELECT CHAR_LENGTH('KAIKEBA');7
SELECT CHAR_LENGTH('开课吧');3
CONCAT(S1,S2,……)将字符串连接到一起
SELECT CONCAT('S','S','M');SSM
SELECT CONCAT('S',' ','M');SM
SELECT CONCAT('S','S',NULL);NULL字符串中有NULL,结果为NULL.
CONCAT_WS(S1,S2,……)以指定的分隔符将字符串连接到一起
SELECT CONCAT_WS('#','S','w','M');S#w#M
SELECTCONCAT_WS('#','S','w','M',NULL);S#w#M
SELECT CONCAT_WS(NULL,'S','w','M');NULL
UPPER(S)/UCASE(S)将字符串中的小写变大写
SELECTUPPER('RanDongmei'),UCASE('RanDongmei');RANDONGMEI RANDONGMEI
LOWER(s)/LCASE(S)将字符串中的大写变小写
LEFT(S,N)/RIGHT(S,N)返回字符串S前N个字符,后N个字符
SELECT LEFT('kaikeba',3);kai
SELECT RIGHT('天天向上,加油',2);油
LPAD|RPAD使用指定字符左填充或右填充至规定字符数
SELECT LPAD('KAI',5,'!');!!KAI
SELECT RPAD('KAI',5,'!');KAI!!
LTRIM|RTRIM|TRIM去掉字符串左边|右边|两边的空格
SELECT ' abc';
SELECT CONCAT('+',' AVC ','+');+ AVC +
SELECT CONCAT('+',LTRIM(' AVC '),'+');+AVC+
SELECT CONCAT('+',RTRIM(' AVC '),'+');+AVC+
SELECT CONCAT('+',TRIM(' AVC '),'+');+AVC+
只有TRIM采有下面两种形式,LTRIM与RTRIM没有
SELECT TRIM('ABCBA'FROM 'A');A
SELECT TRIM('A'FROM 'ABCNA');BCN
SELECT TRIM('A'FROM 'ABCANA');BCAN
REPEAT(S,N)将字符串S重复N次
SELECT REPEAT('A',10);AAAAAAAAAA
SPACE(N)填充N个空格
SELECT SPACE(5);
SELECT CONCAT('+',SPACE(5),'+');+ +
REPLACE(S,S1,S2);将字符串S中的S1替换为S2
SELECTREPLACE('AAAASDDFO','A','R');RRRRSDDFO
STRCMP(S1,S2);比较字符串S1和S2,若相等返回0,若S1>S2返回1,若S1 SELECT STRCMP('A','A');0 SELECT STRCMP('A','B');-1 SELECT STRCMP('B','A');1第一个字符串大于第二个字符串 SELECT STRCMP('A','a');0不区分大小写 SUBSTRINT(S,a,b)从字符串的第a个字符取到第b个字符 SELECT SUBSTRING('KAIKEBA',1,3);KAI 从1开始,截取三个字符 SELECT SUBSTRING('KAIKEBA',-2,3);BA SELECT SUBSTRING('KAIKEBA',-2,1);B REVERSE(S);反转字符串S SELECT REVERSE('ABCDE');EDCBA ELT(N,S1,S2,S3,……);返回指定位置的字符串 SELECT ELT(3,'a','b','c','d');c 3.日期时间函数 返回当前日期 SELECT CURDATE(); SELECT CURRENT_DATE(); 返回当前时间 SELECT CURTIME(); SELECT CURRENT_TIME(); 返回当前日期时间 SELECT NOW();2014-11-07 SELECT SYSDATE(); 返回月份 SELECT MONTH('2014-12-16');12 SELECT MONTHNAME(NOW());NOVEMBER 返回星期几 SELECT DAYNAME(NOW());Friday 一周的第几天,1:星期日 SELECT DAYOFWEEK(NOW());6 返回日期是星期几,0代表星期一 SELECT WEEKDAY(NOW());4 SELECT WEEK(NOW());44一年中的第44个星期 SELECT YEAR(NOW());2014 SELECT HOUR(NOW()); SELECT MINUTE(NOW()); SELECT SECOND(NOW()); 计算两个日期间相隔天数 SELECTDATEDIFF('1988-12-16','2014-11-07');-9457天 SELECTDATEDIFF('1964-04-16','2014-11-07');-18467天 4.系统函数 SELECT VERSION();当前数据库版本号 SELECT CONNECTION_ID();当前服务器的连接数 当前数据库: SELECT DATABASE(); SELECT SCHEMA(); 当前用户 SELECT USER(); SELECT SYSTEM_USER(); SELECT CURRENT_USER(); SELECT CURRENT_USER; 返回字符串STR的字符集 SELECT CHARSET('AFA'); SELECT LAST_INSERT_ID();最后一条插入记录ID号 5.加密函数 MD5() PASSWORD(); SELECT MD5('ROOT'); SELECT PASSWORD('ROOT'); PASSWORD针对用户密码加密 SELECT * FROM user WHERE User='root'\G; 添加权限时需要添加PASSWORD密码 6.流程函数 IF SELECT IF(3>1,'A','B'); SELECT id,username,IF(age>18,'成年','未成年') FROM employee; SELECT IFNULL(NULL,'THIS IS NULL');THIS ISNULL SELECT IFNULL(1,'THIS IS NULL');1,只有为空时,才能变成后面这个值 二.存储过程 将SQL语句放在集合里,然后调用存储过程和函数来执行已经定义好的这些SQL语句,存储过程和函数可以避免程序开发人员重复编写相同的SQL语句存储过程和函数保存在mysql服务器中的一个存储和执行,可以减少客户端和服务器端数据传输的消耗。 将一组SQL语句组合在一起,并且将这些SQL语句当作一个整体,存储在mysql服务器中。 存储过程就是:存储在mysql服务器的一组当作一个整体执行的SQL语句集合。存储过程运行于服务器端,运行速度比较快,而且存储过程执行一次,它的执行规范驻留在高速缓冲存储器中,在以后的操作中只需要从高速缓冲存储器调用已编译好的二进制代码,可以避免程序开发人员重复编写相同的SQL语句、减少客户端和服务器端数据传输的消耗、提高系统性能和系统响应时间,也可以确保存储过程安全,因为我们使用存储过程可以完成数据库的所有操作,也可以通过编程的方式来控制对数据库操作的访问权限。 CREATE PROCEDURE sp_name ([proc_parameter[...]]) [characteristic...] routine_body 参数:三部分: (1)输入输出的参数IN OUT INOUT (2)名称 (3)类型 特性: LANGUAGE SQL:执行体由SQL组成 DETERMINISTIC执行结果确定:相同输入得到相同输出 NOT DETERMINISTIC执行结果不确定 子程序使用SQL的一个限制: CONTAINS SQL:子程序包含sql语句(默认) NO SQL:子程序中不包含sql语句 READS SQL DATA子程序中包含查询数据语句 MODIFIES SQL DATA子程序中包含写数据语句 谁有权限执行存储过程 SQL SECURITY DEFINER|INVOKER DEFINER:定义者(默认) INVOKER:调用者 注释 COMMENT 'string' 1>创建存储过程 改变分解符 DELIMITER // CREATE PROCEDURE sp_demo() BEGIN SELECT * FROM user; END // DELIMITER ; DELIMITER // CREATE PROCEDURE age_from_user(IN user_idINT,OUT user_age INT) READS SQL DATA BEGIN SELECT age FROM user WHERE id=user_id; END // DELIMITER ; 2>创建存储函数 CREATE FUNCTION sp_name [func_parameter[..]] RETURNS type DELIMITER // CREATE FUNCTION username_from_user(user_idINT) RETURNS VARCHAR(20) BEGIN RETURN (SELECT username FROM user WHERE id=user_id); END // DELIMITER ; 3>调用存储过程和函数 CALL sp_name([paramer..]) 调用时必须有权限 CALL sp_demo(); CALL age_from_user(1,@user_age); CALL age_from_user(2,@user_age); 调用存储函数 SELECT username_from_user(3); 4>查看创建好的存储过程和函数 SHOW PROCEDURE STATUS LIKE 'sp_demo'\G; SHOW FUNCTION STATUS LIKE'username_from_user'\G; 具体存储过程与函数的定义 SHOW CREATE PROCEDURE sp_demo\G; SHOW CREATE FUNCTION username_from_user\G; 创建的存储过程与函数存在information_schema数据库下面的ROUTINES表中 USE information_schema; SELECT * FROM ROUTINES\G; 5>修改存储过程与函数 ALTER PROCEDURE|FUNCTION ALTER PROCEDURE sp_demo COMMENT 'THIS IS ATEST PROCEDURE'; SHOW CREATE PROCEDURE sp_demo\G; ALTER FUNCTION username_from_user COMMENT'THIS IS A TEST FUNCTION'; SHOW CREATE FUNCTION username_from_user\G; 6>删除存储过程与函数 DROP PROCEDURE sp_demo; DROP PROCEDURE IF EXISTS sp_demo; SHOW WARNINGS; DROP FUNCTION username_from_user; 存储过程运行于服务器端,运行速度比较快,而且存储过程执行一次,它的执行规范驻留在高速缓冲存储器中,在以后的 操作中只需要从高速缓冲存储器调用已编译好的二进制代码,提高系统性能和系统响应时间。也可以确保存储过程安全,因为我们使用存储过程可以完成数据库的所有操作,也可以通过编程的方式来控制对数据库操作的访问权限。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Go語言提供了兩種動態函數創建技術:closures和反射。 closures允許存取閉包作用域內的變量,而反射可使用FuncOf函數建立新函數。這些技術在自訂HTTP路由器、實現高度可自訂的系統和建置可插拔的元件方面非常有用。

在C++函數命名中,考慮參數順序至關重要,可提高可讀性、減少錯誤並促進重構。常見的參數順序約定包括:動作-物件、物件-動作、語意意義和遵循標準函式庫。最佳順序取決於函數目的、參數類型、潛在混淆和語言慣例。

1. SUM函數,用於對一列或一組單元格中的數字進行求和,例如:=SUM(A1:J10)。 2、AVERAGE函數,用於計算一列或一組儲存格中的數字的平均值,例如:=AVERAGE(A1:A10)。 3.COUNT函數,用於計算一列或一組單元格中的數字或文字的數量,例如:=COUNT(A1:A10)4、IF函數,用於根據指定的條件進行邏輯判斷,並返回相應的結果。

C++函數中預設參數的優點包括簡化呼叫、增強可讀性、避免錯誤。缺點是限制靈活性、命名限制。可變參數的優點包括無限彈性、動態綁定。缺點包括複雜性更高、隱式型別轉換、除錯困難。

C++中的函數傳回參考類型的好處包括:效能提升:引用傳遞避免了物件複製,從而節省了記憶體和時間。直接修改:呼叫方可以直接修改傳回的參考對象,而無需重新賦值。程式碼簡潔:引用傳遞簡化了程式碼,無需額外的賦值操作。

自訂PHP函數與預定義函數的差異在於:作用域:自訂函數僅限於其定義範圍,而預定義函數可在整個腳本中存取。定義方式:自訂函數使用function關鍵字定義,而預先定義函數則由PHP核心定義。參數傳遞:自訂函數接收參數,而預先定義函數可能不需要參數。擴充性:自訂函數可以根據需要創建,而預定義函數是內建的且無法修改。

C++中的異常處理可透過自訂異常類別增強,提供特定錯誤訊息、上下文資訊以及根據錯誤類型執行自訂操作。定義繼承自std::exception的異常類,提供特定的錯誤訊息。使用throw關鍵字拋出自訂異常。在try-catch區塊中使用dynamic_cast將捕獲到的異常轉換為自訂異常類型。在實戰案例中,open_file函數會拋出FileNotFoundException異常,捕捉並處理該異常可提供更具體的錯誤訊息。
