日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

mysql5720_Mysql内置功能《五》 函数

發布時間:2025/3/20 数据库 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql5720_Mysql内置功能《五》 函数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一 函數

MySQL中提供了許多內置函數,例如:

一、數學函數

ROUND(x,y)

返回參數x的四舍五入的有y位小數的值

RAND()

返回0到1內的隨機值,可以通過提供一個參數(種子)使RAND()隨機數生成器生成一個指定的值。

二、聚合函數(常用于GROUP BY從句的SELECT查詢中)

AVG(col)返回指定列的平均值

COUNT(col)返回指定列中非NULL值的個數

MIN(col)返回指定列的最小值

MAX(col)返回指定列的最大值

SUM(col)返回指定列的所有值之和

GROUP_CONCAT(col) 返回由屬于一組的列值連接組合而成的結果

三、字符串函數

CHAR_LENGTH(str)

返回值為字符串str 的長度,長度的單位為字符。一個多字節字符算作一個單字符。

CONCAT(str1,str2,...)

字符串拼接

如有任何一個參數為NULL ,則返回值為 NULL。

CONCAT_WS(separator,str1,str2,...)

字符串拼接(自定義連接符)

CONCAT_WS()不會忽略任何空字符串。 (然而會忽略所有的 NULL)。

CONV(N,from_base,to_base)

進制轉換

例如:

SELECT CONV('a',16,2); 表示將 a 由16進制轉換為2進制字符串表示

FORMAT(X,D)

將數字X 的格式寫為'#,###,###.##',以四舍五入的方式保留小數點后 D 位, 并將結果以字符串的形式返回。若 D 為 0, 則返回結果不帶有小數點,或不含小數部分。

例如:

SELECT FORMAT(12332.1,4); 結果為: '12,332.1000'

INSERT(str,pos,len,newstr)

在str的指定位置插入字符串

pos:要替換位置其實位置

len:替換的長度

newstr:新字符串

特別的:

如果pos超過原字符串長度,則返回原字符串

如果len超過原字符串長度,則由新字符串完全替換

INSTR(str,substr)

返回字符串 str 中子字符串的第一個出現位置。

LEFT(str,len)

返回字符串str 從開始的len位置的子序列字符。

LOWER(str)

變小寫

UPPER(str)

變大寫

REVERSE(str)

返回字符串 str ,順序和字符順序相反。

SUBSTRING(str,pos) , SUBSTRING(str FROM pos) SUBSTRING(str,pos,len) , SUBSTRING(str FROM pos FOR len)

不帶有len 參數的格式從字符串str返回一個子字符串,起始于位置 pos。帶有len參數的格式從字符串str返回一個長度同len字符相同的子字符串,起始于位置 pos。 使用 FROM的格式為標準 SQL 語法。也可能對pos使用一個負值。假若這樣,則子字符串的位置起始于字符串結尾的pos 字符,而不是字符串的開頭位置。在以下格式的函數中可以對pos 使用一個負值。

mysql> SELECT SUBSTRING('Quadratically',5);

-> 'ratically'

mysql> SELECT SUBSTRING('foobarbar' FROM 4);

-> 'barbar'

mysql> SELECT SUBSTRING('Quadratically',5,6);

-> 'ratica'

mysql> SELECT SUBSTRING('Sakila', -3);

-> 'ila'

mysql> SELECT SUBSTRING('Sakila', -5, 3);

-> 'aki'

mysql> SELECT SUBSTRING('Sakila' FROM -4 FOR 2);

-> 'ki'

四、日期和時間函數

CURDATE()或CURRENT_DATE() 返回當前的日期

CURTIME()或CURRENT_TIME() 返回當前的時間

DAYOFWEEK(date) 返回date所代表的一星期中的第幾天(1~7)

DAYOFMONTH(date) 返回date是一個月的第幾天(1~31)

DAYOFYEAR(date) 返回date是一年的第幾天(1~366)

DAYNAME(date) 返回date的星期名,如:SELECT DAYNAME(CURRENT_DATE);

FROM_UNIXTIME(ts,fmt) 根據指定的fmt格式,格式化UNIX時間戳ts

HOUR(time) 返回time的小時值(0~23)

MINUTE(time) 返回time的分鐘值(0~59)

MONTH(date) 返回date的月份值(1~12)

MONTHNAME(date) 返回date的月份名,如:SELECT MONTHNAME(CURRENT_DATE);

NOW() 返回當前的日期和時間

QUARTER(date) 返回date在一年中的季度(1~4),如SELECT QUARTER(CURRENT_DATE);

WEEK(date) 返回日期date為一年中第幾周(0~53)

YEAR(date) 返回日期date的年份(1000~9999)

重點:

DATE_FORMAT(date,format) 根據format字符串格式化date值

mysql> SELECT DATE_FORMAT('2009-10-04 22:23:00', '%W %M %Y');

-> 'Sunday October 2009'

mysql> SELECT DATE_FORMAT('2007-10-04 22:23:00', '%H:%i:%s');

-> '22:23:00'

mysql> SELECT DATE_FORMAT('1900-10-04 22:23:00',

-> '%D %y %a %d %m %b %j');

-> '4th 00 Thu 04 10 Oct 277'

mysql> SELECT DATE_FORMAT('1997-10-04 22:23:00',

-> '%H %k %I %r %T %S %w');

-> '22 22 10 10:23:00 PM 22:23:00 00 6'

mysql> SELECT DATE_FORMAT('1999-01-01', '%X %V');

-> '1998 52'

mysql> SELECT DATE_FORMAT('2006-06-00', '%d');

-> '00'

五、加密函數

MD5()

計算字符串str的MD5校驗和

PASSWORD(str)

返回字符串str的加密版本,這個加密過程是不可逆轉的,和UNIX密碼加密過程使用不同的算法。

六、控制流函數

CASE WHEN[test1] THEN [result1]...ELSE [default] END

如果testN是真,則返回resultN,否則返回default

CASE [test] WHEN[val1] THEN [result]...ELSE [default]END

如果test和valN相等,則返回resultN,否則返回default

IF(test,t,f)

如果test是真,返回t;否則返回f

IFNULL(arg1,arg2)

如果arg1不是空,返回arg1,否則返回arg2

NULLIF(arg1,arg2)

如果arg1=arg2返回NULL;否則返回arg1

七、控制流函數小練習

#7.1、準備表

/*

Navicat MySQL Data Transfer

Source Server : localhost_3306

Source Server Version : 50720

Source Host : localhost:3306

Source Database : student

Target Server Type : MYSQL

Target Server Version : 50720

File Encoding : 65001

Date: 2018-01-02 12:05:30

*/

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------

-- Table structure for course

-- ----------------------------

DROP TABLE IF EXISTS `course`;

CREATE TABLE `course` (

`c_id` int(11) NOT NULL,

`c_name` varchar(255) DEFAULT NULL,

`t_id` int(11) DEFAULT NULL,

PRIMARY KEY (`c_id`),

KEY `t_id` (`t_id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------

-- Records of course

-- ----------------------------

INSERT INTO `course` VALUES ('1', 'python', '1');

INSERT INTO `course` VALUES ('2', 'java', '2');

INSERT INTO `course` VALUES ('3', 'linux', '3');

INSERT INTO `course` VALUES ('4', 'web', '2');

-- ----------------------------

-- Table structure for score

-- ----------------------------

DROP TABLE IF EXISTS `score`;

CREATE TABLE `score` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`s_id` int(10) DEFAULT NULL,

`c_id` int(11) DEFAULT NULL,

`num` double DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=utf8;

-- ----------------------------

-- Records of score

-- ----------------------------

INSERT INTO `score` VALUES ('1', '1', '1', '79');

INSERT INTO `score` VALUES ('2', '1', '2', '78');

INSERT INTO `score` VALUES ('3', '1', '3', '35');

INSERT INTO `score` VALUES ('4', '2', '2', '32');

INSERT INTO `score` VALUES ('5', '3', '1', '66');

INSERT INTO `score` VALUES ('6', '4', '2', '77');

INSERT INTO `score` VALUES ('7', '4', '1', '68');

INSERT INTO `score` VALUES ('8', '5', '1', '66');

INSERT INTO `score` VALUES ('9', '2', '1', '69');

INSERT INTO `score` VALUES ('10', '4', '4', '75');

INSERT INTO `score` VALUES ('11', '5', '4', '66.7');

-- ----------------------------

-- Table structure for student

-- ----------------------------

DROP TABLE IF EXISTS `student`;

CREATE TABLE `student` (

`s_id` varchar(20) NOT NULL,

`s_name` varchar(255) DEFAULT NULL,

`s_age` int(10) DEFAULT NULL,

`s_sex` char(1) DEFAULT NULL,

PRIMARY KEY (`s_id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------

-- Records of student

-- ----------------------------

INSERT INTO `student` VALUES ('1', '魯班', '12', '男');

INSERT INTO `student` VALUES ('2', '貂蟬', '20', '女');

INSERT INTO `student` VALUES ('3', '劉備', '35', '男');

INSERT INTO `student` VALUES ('4', '關羽', '34', '男');

INSERT INTO `student` VALUES ('5', '張飛', '33', '女');

-- ----------------------------

-- Table structure for teacher

-- ----------------------------

DROP TABLE IF EXISTS `teacher`;

CREATE TABLE `teacher` (

`t_id` int(10) NOT NULL,

`t_name` varchar(50) DEFAULT NULL,

PRIMARY KEY (`t_id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------

-- Records of teacher

-- ----------------------------

INSERT INTO `teacher` VALUES ('1', '大王');

INSERT INTO `teacher` VALUES ('2', 'alex');

INSERT INTO `teacher` VALUES ('3', 'egon');

INSERT INTO `teacher` VALUES ('4', 'peiqi');

#7.2、統計各科各分數段人數.顯示格式:課程ID,課程名稱,[100-85],[85-70],[70-60],[ <60]

select score.c_id,

course.c_name,

sum(CASE WHEN num BETWEEN 85 and 100 THEN 1 ELSE 0 END) as '[100-85]',

sum(CASE WHEN num BETWEEN 70 and 85 THEN 1 ELSE 0 END) as '[85-70]',

sum(CASE WHEN num BETWEEN 60 and 70 THEN 1 ELSE 0 END) as '[70-60]',

sum(CASE WHEN num < 60 THEN 1 ELSE 0 END) as '[ <60]'

from score,course where score.c_id=course.c_id GROUP BY score.c_id;

#1 基本使用

mysql> SELECT DATE_FORMAT('2009-10-04 22:23:00', '%W %M %Y');

-> 'Sunday October 2009'

mysql> SELECT DATE_FORMAT('2007-10-04 22:23:00', '%H:%i:%s');

-> '22:23:00'

mysql> SELECT DATE_FORMAT('1900-10-04 22:23:00',

-> '%D %y %a %d %m %b %j');

-> '4th 00 Thu 04 10 Oct 277'

mysql> SELECT DATE_FORMAT('1997-10-04 22:23:00',

-> '%H %k %I %r %T %S %w');

-> '22 22 10 10:23:00 PM 22:23:00 00 6'

mysql> SELECT DATE_FORMAT('1999-01-01', '%X %V');

-> '1998 52'

mysql> SELECT DATE_FORMAT('2006-06-00', '%d');

-> '00'

#2 準備表和記錄

CREATE TABLE blog (

id INT PRIMARY KEY auto_increment,

NAME CHAR (32),

sub_time datetime

);

INSERT INTO blog (NAME, sub_time)

VALUES

('第1篇','2015-03-01 11:31:21'),

('第2篇','2015-03-11 16:31:21'),

('第3篇','2016-07-01 10:21:31'),

('第4篇','2016-07-22 09:23:21'),

('第5篇','2016-07-23 10:11:11'),

('第6篇','2016-07-25 11:21:31'),

('第7篇','2017-03-01 15:33:21'),

('第8篇','2017-03-01 17:32:21'),

('第9篇','2017-03-01 18:31:21');

#3. 提取sub_time字段的值,按照格式后的結果即"年月"來分組

SELECT DATE_FORMAT(sub_time,'%Y-%m'),COUNT(1) FROM blog GROUP BY DATE_FORMAT(sub_time,'%Y-%m');

#結果

+-------------------------------+----------+

| DATE_FORMAT(sub_time,'%Y-%m') | COUNT(1) |

+-------------------------------+----------+

| 2015-03 | 2 |

| 2016-07 | 4 |

| 2017-03 | 3 |

+-------------------------------+----------+

rows in set (0.00 sec)

需要掌握函數:date_format

一 自定義函數

#!!!注意!!!

#函數中不要寫sql語句(否則會報錯),函數僅僅只是一個功能,是一個在sql中被應用的功能

#若要想在begin...end...中寫sql,請用存儲過程

delimiter //

create function f1(

i1 int,

i2 int)

returns int

BEGIN

declare num int;

set num = i1 + i2;

return(num);

END //

delimiter ;

delimiter //

create function f5(

i int

)

returns int

begin

declare res int default 0;

if i = 10 then

set res=100;

elseif i = 20 then

set res=200;

elseif i = 30 then

set res=300;

else

set res=400;

一 函數

MySQL中提供了許多內置函數,例如:

一、數學函數

ROUND(x,y)

返回參數x的四舍五入的有y位小數的值

RAND()

返回0到1內的隨機值,可以通過提供一個參數(種子)使RAND()隨機數生成器生成一個指定的值。

二、聚合函數(常用于GROUP BY從句的SELECT查詢中)

AVG(col)返回指定列的平均值

COUNT(col)返回指定列中非NULL值的個數

MIN(col)返回指定列的最小值

MAX(col)返回指定列的最大值

SUM(col)返回指定列的所有值之和

GROUP_CONCAT(col) 返回由屬于一組的列值連接組合而成的結果

三、字符串函數

CHAR_LENGTH(str)

返回值為字符串str 的長度,長度的單位為字符。一個多字節字符算作一個單字符。

CONCAT(str1,str2,...)

字符串拼接

如有任何一個參數為NULL ,則返回值為 NULL。

CONCAT_WS(separator,str1,str2,...)

字符串拼接(自定義連接符)

CONCAT_WS()不會忽略任何空字符串。 (然而會忽略所有的 NULL)。

CONV(N,from_base,to_base)

進制轉換

例如:

SELECT CONV('a',16,2); 表示將 a 由16進制轉換為2進制字符串表示

FORMAT(X,D)

將數字X 的格式寫為'#,###,###.##',以四舍五入的方式保留小數點后 D 位, 并將結果以字符串的形式返回。若 D 為 0, 則返回結果不帶有小數點,或不含小數部分。

例如:

SELECT FORMAT(12332.1,4); 結果為: '12,332.1000'

INSERT(str,pos,len,newstr)

在str的指定位置插入字符串

pos:要替換位置其實位置

len:替換的長度

newstr:新字符串

特別的:

如果pos超過原字符串長度,則返回原字符串

如果len超過原字符串長度,則由新字符串完全替換

INSTR(str,substr)

返回字符串 str 中子字符串的第一個出現位置。

LEFT(str,len)

返回字符串str 從開始的len位置的子序列字符。

LOWER(str)

變小寫

UPPER(str)

變大寫

REVERSE(str)

返回字符串 str ,順序和字符順序相反。

SUBSTRING(str,pos) , SUBSTRING(str FROM pos) SUBSTRING(str,pos,len) , SUBSTRING(str FROM pos FOR len)

不帶有len 參數的格式從字符串str返回一個子字符串,起始于位置 pos。帶有len參數的格式從字符串str返回一個長度同len字符相同的子字符串,起始于位置 pos。 使用 FROM的格式為標準 SQL 語法。也可能對pos使用一個負值。假若這樣,則子字符串的位置起始于字符串結尾的pos 字符,而不是字符串的開頭位置。在以下格式的函數中可以對pos 使用一個負值。

mysql> SELECT SUBSTRING('Quadratically',5);

-> 'ratically'

mysql> SELECT SUBSTRING('foobarbar' FROM 4);

-> 'barbar'

mysql> SELECT SUBSTRING('Quadratically',5,6);

-> 'ratica'

mysql> SELECT SUBSTRING('Sakila', -3);

-> 'ila'

mysql> SELECT SUBSTRING('Sakila', -5, 3);

-> 'aki'

mysql> SELECT SUBSTRING('Sakila' FROM -4 FOR 2);

-> 'ki'

四、日期和時間函數

CURDATE()或CURRENT_DATE() 返回當前的日期

CURTIME()或CURRENT_TIME() 返回當前的時間

DAYOFWEEK(date) 返回date所代表的一星期中的第幾天(1~7)

DAYOFMONTH(date) 返回date是一個月的第幾天(1~31)

DAYOFYEAR(date) 返回date是一年的第幾天(1~366)

DAYNAME(date) 返回date的星期名,如:SELECT DAYNAME(CURRENT_DATE);

FROM_UNIXTIME(ts,fmt) 根據指定的fmt格式,格式化UNIX時間戳ts

HOUR(time) 返回time的小時值(0~23)

MINUTE(time) 返回time的分鐘值(0~59)

MONTH(date) 返回date的月份值(1~12)

MONTHNAME(date) 返回date的月份名,如:SELECT MONTHNAME(CURRENT_DATE);

NOW() 返回當前的日期和時間

QUARTER(date) 返回date在一年中的季度(1~4),如SELECT QUARTER(CURRENT_DATE);

WEEK(date) 返回日期date為一年中第幾周(0~53)

YEAR(date) 返回日期date的年份(1000~9999)

重點:

DATE_FORMAT(date,format) 根據format字符串格式化date值

mysql> SELECT DATE_FORMAT('2009-10-04 22:23:00', '%W %M %Y');

-> 'Sunday October 2009'

mysql> SELECT DATE_FORMAT('2007-10-04 22:23:00', '%H:%i:%s');

-> '22:23:00'

mysql> SELECT DATE_FORMAT('1900-10-04 22:23:00',

-> '%D %y %a %d %m %b %j');

-> '4th 00 Thu 04 10 Oct 277'

mysql> SELECT DATE_FORMAT('1997-10-04 22:23:00',

-> '%H %k %I %r %T %S %w');

-> '22 22 10 10:23:00 PM 22:23:00 00 6'

mysql> SELECT DATE_FORMAT('1999-01-01', '%X %V');

-> '1998 52'

mysql> SELECT DATE_FORMAT('2006-06-00', '%d');

-> '00'

五、加密函數

MD5()

計算字符串str的MD5校驗和

PASSWORD(str)

返回字符串str的加密版本,這個加密過程是不可逆轉的,和UNIX密碼加密過程使用不同的算法。

六、控制流函數

CASE WHEN[test1] THEN [result1]...ELSE [default] END

如果testN是真,則返回resultN,否則返回default

CASE [test] WHEN[val1] THEN [result]...ELSE [default]END

如果test和valN相等,則返回resultN,否則返回default

IF(test,t,f)

如果test是真,返回t;否則返回f

IFNULL(arg1,arg2)

如果arg1不是空,返回arg1,否則返回arg2

NULLIF(arg1,arg2)

如果arg1=arg2返回NULL;否則返回arg1

七、控制流函數小練習

#7.1、準備表

/*

Navicat MySQL Data Transfer

Source Server : localhost_3306

Source Server Version : 50720

Source Host : localhost:3306

Source Database : student

Target Server Type : MYSQL

Target Server Version : 50720

File Encoding : 65001

Date: 2018-01-02 12:05:30

*/

SET FOREIGN_KEY_CHECKS=0;

-- ----------------------------

-- Table structure for course

-- ----------------------------

DROP TABLE IF EXISTS `course`;

CREATE TABLE `course` (

`c_id` int(11) NOT NULL,

`c_name` varchar(255) DEFAULT NULL,

`t_id` int(11) DEFAULT NULL,

PRIMARY KEY (`c_id`),

KEY `t_id` (`t_id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------

-- Records of course

-- ----------------------------

INSERT INTO `course` VALUES ('1', 'python', '1');

INSERT INTO `course` VALUES ('2', 'java', '2');

INSERT INTO `course` VALUES ('3', 'linux', '3');

INSERT INTO `course` VALUES ('4', 'web', '2');

-- ----------------------------

-- Table structure for score

-- ----------------------------

DROP TABLE IF EXISTS `score`;

CREATE TABLE `score` (

`id` int(11) NOT NULL AUTO_INCREMENT,

`s_id` int(10) DEFAULT NULL,

`c_id` int(11) DEFAULT NULL,

`num` double DEFAULT NULL,

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=utf8;

-- ----------------------------

-- Records of score

-- ----------------------------

INSERT INTO `score` VALUES ('1', '1', '1', '79');

INSERT INTO `score` VALUES ('2', '1', '2', '78');

INSERT INTO `score` VALUES ('3', '1', '3', '35');

INSERT INTO `score` VALUES ('4', '2', '2', '32');

INSERT INTO `score` VALUES ('5', '3', '1', '66');

INSERT INTO `score` VALUES ('6', '4', '2', '77');

INSERT INTO `score` VALUES ('7', '4', '1', '68');

INSERT INTO `score` VALUES ('8', '5', '1', '66');

INSERT INTO `score` VALUES ('9', '2', '1', '69');

INSERT INTO `score` VALUES ('10', '4', '4', '75');

INSERT INTO `score` VALUES ('11', '5', '4', '66.7');

-- ----------------------------

-- Table structure for student

-- ----------------------------

DROP TABLE IF EXISTS `student`;

CREATE TABLE `student` (

`s_id` varchar(20) NOT NULL,

`s_name` varchar(255) DEFAULT NULL,

`s_age` int(10) DEFAULT NULL,

`s_sex` char(1) DEFAULT NULL,

PRIMARY KEY (`s_id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------

-- Records of student

-- ----------------------------

INSERT INTO `student` VALUES ('1', '魯班', '12', '男');

INSERT INTO `student` VALUES ('2', '貂蟬', '20', '女');

INSERT INTO `student` VALUES ('3', '劉備', '35', '男');

INSERT INTO `student` VALUES ('4', '關羽', '34', '男');

INSERT INTO `student` VALUES ('5', '張飛', '33', '女');

-- ----------------------------

-- Table structure for teacher

-- ----------------------------

DROP TABLE IF EXISTS `teacher`;

CREATE TABLE `teacher` (

`t_id` int(10) NOT NULL,

`t_name` varchar(50) DEFAULT NULL,

PRIMARY KEY (`t_id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

-- ----------------------------

-- Records of teacher

-- ----------------------------

INSERT INTO `teacher` VALUES ('1', '大王');

INSERT INTO `teacher` VALUES ('2', 'alex');

INSERT INTO `teacher` VALUES ('3', 'egon');

INSERT INTO `teacher` VALUES ('4', 'peiqi');

#7.2、統計各科各分數段人數.顯示格式:課程ID,課程名稱,[100-85],[85-70],[70-60],[ <60]

select score.c_id,

course.c_name,

sum(CASE WHEN num BETWEEN 85 and 100 THEN 1 ELSE 0 END) as '[100-85]',

sum(CASE WHEN num BETWEEN 70 and 85 THEN 1 ELSE 0 END) as '[85-70]',

sum(CASE WHEN num BETWEEN 60 and 70 THEN 1 ELSE 0 END) as '[70-60]',

sum(CASE WHEN num < 60 THEN 1 ELSE 0 END) as '[ <60]'

from score,course where score.c_id=course.c_id GROUP BY score.c_id;

#1 基本使用

mysql> SELECT DATE_FORMAT('2009-10-04 22:23:00', '%W %M %Y');

-> 'Sunday October 2009'

mysql> SELECT DATE_FORMAT('2007-10-04 22:23:00', '%H:%i:%s');

-> '22:23:00'

mysql> SELECT DATE_FORMAT('1900-10-04 22:23:00',

-> '%D %y %a %d %m %b %j');

-> '4th 00 Thu 04 10 Oct 277'

mysql> SELECT DATE_FORMAT('1997-10-04 22:23:00',

-> '%H %k %I %r %T %S %w');

-> '22 22 10 10:23:00 PM 22:23:00 00 6'

mysql> SELECT DATE_FORMAT('1999-01-01', '%X %V');

-> '1998 52'

mysql> SELECT DATE_FORMAT('2006-06-00', '%d');

-> '00'

#2 準備表和記錄

CREATE TABLE blog (

id INT PRIMARY KEY auto_increment,

NAME CHAR (32),

sub_time datetime

);

INSERT INTO blog (NAME, sub_time)

VALUES

('第1篇','2015-03-01 11:31:21'),

('第2篇','2015-03-11 16:31:21'),

('第3篇','2016-07-01 10:21:31'),

('第4篇','2016-07-22 09:23:21'),

('第5篇','2016-07-23 10:11:11'),

('第6篇','2016-07-25 11:21:31'),

('第7篇','2017-03-01 15:33:21'),

('第8篇','2017-03-01 17:32:21'),

('第9篇','2017-03-01 18:31:21');

#3. 提取sub_time字段的值,按照格式后的結果即"年月"來分組

SELECT DATE_FORMAT(sub_time,'%Y-%m'),COUNT(1) FROM blog GROUP BY DATE_FORMAT(sub_time,'%Y-%m');

#結果

+-------------------------------+----------+

| DATE_FORMAT(sub_time,'%Y-%m') | COUNT(1) |

+-------------------------------+----------+

| 2015-03 | 2 |

| 2016-07 | 4 |

| 2017-03 | 3 |

+-------------------------------+----------+

rows in set (0.00 sec)

需要掌握函數:date_format

一 自定義函數

#!!!注意!!!

#函數中不要寫sql語句(否則會報錯),函數僅僅只是一個功能,是一個在sql中被應用的功能

#若要想在begin...end...中寫sql,請用存儲過程

delimiter //

create function f1(

i1 int,

i2 int)

returns int

BEGIN

declare num int;

set num = i1 + i2;

return(num);

END //

delimiter ;

delimiter //

create function f5(

i int

)

returns int

begin

declare res int default 0;

if i = 10 then

set res=100;

elseif i = 20 then

set res=200;

elseif i = 30 then

set res=300;

else

set res=400;

end if;

return res;

end //

delimiter ;

二 刪除函數

drop function func_name;

三 執行函數

# 獲取返回值

select UPPER('egon') into @res;

SELECT @res;

# 在查詢中使用

select f1(11,nid) ,name from tb2;

end if; return res; end // delimiter ;

二 刪除函數

drop function func_name;

三 執行函數

# 獲取返回值

select UPPER('egon') into @res;

SELECT @res;

# 在查詢中使用

select f1(11,nid) ,name from tb2;

總結

以上是生活随笔為你收集整理的mysql5720_Mysql内置功能《五》 函数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 茄子av | 精品电影一区二区 | 日本少妇吞精囗交视频 | 日本三级影院 | 久久咪咪 | 日本中文有码 | 久久久久久18 | 91成人精品国产刺激国语对白 | 中文字幕日韩电影 | 初尝人妻少妇中文字幕 | 国产精品一区在线看 | 91免费高清在线观看 | 老女人毛片 | 欧美色鬼 | 艹少妇视频 | 久久国产毛片 | 成人无码av片在线观看 | 激情四射综合网 | 欧美成人三级在线播放 | 四虎国产精品永久免费观看视频 | 久久久久久伊人 | 亚洲同性gay激情无套 | 成人免费无码大片a毛片抽搐色欲 | 亚洲激情第一页 | 蜜臀aⅴ国产精品久久久国产老师 | 人人爱人人看 | 午夜少妇av | 欧美日韩少妇精品 | 性做爰裸体按摩视频 | 国产亚洲区| 欧美色亚洲色 | 亚洲av无码一区二区二三区软件 | 欧美性猛交69 | 免费a级片在线观看 | 18av在线视频 | 美女露出让男生揉的视频 | 有声小说 成人专区 | 超碰caopeng | 欧美日韩高清 | 男插女视频网站 | 免费看aaaaa级少淫片 | brazzers猛女系列| 国产三区在线观看 | 日韩综合中文字幕 | 日韩毛片在线播放 | 九月婷婷色| 一级黄色片免费在线观看 | 喷潮在线 | 黄色片毛片 | 白浆网站 | 日韩精品一区二区三区在线 | 日韩a在线观看 | 在线超碰av | 亚洲AV无码国产精品午夜字幕 | 免费91看片 | 老熟妇仑乱一区二区视频 | 精品无人国产偷自产在线 | wwww黄色片 | 99久久99九九99九九九 | 中文免费av| 中文字幕啪啪 | 黄色大片中文字幕 | 深夜视频一区二区 | 国产chinese中国hdxxxx | 国产精品6 | 亚洲高清无码久久 | 国产农村妇女精品久久久 | 一级二级三级黄色片 | 国产精品国产三级国产传播 | 蜜桃臀aⅴ精品一区二区三区 | 欧美劲爆第一页 | 国产激情第一页 | 婷婷色在线 | 成人免费视频软件网站 | 国产精品日日摸天天碰 | 欧美粗又大| 欧日韩在线 | 男插女视频网站 | 国产盗摄一区二区三区 | 国产视频二 | 超碰在线97观看 | 性xxxfllreexxx少妇 | 潘金莲裸体一级淫片视频 | 午夜久 | 欧美一区二区三区久久久 | 日韩黄色免费 | 久久性精品 | 超色视频| 欧美一区二区在线观看视频 | 国产精品11| 亚洲无毛 | 日韩一区久久 | 91一区二区三区在线观看 | 国产成人综合一区二区三区 | av噜噜在线| 久久久午夜影院 | 久久综合操 | 黄色激情网站 | jizzjizz日本人 |