Mysql运算符与函数(胖胖老师)

use test;
create table `employee`(
    emp_no int unsigned,
    emp_name varchar(30),
    emp_sex varchar(3),
    emp_age tinyint unsigned,
    sal double,
    history datetime
);
insert into employee values(1, ‘张三‘, ‘男‘, 18, 5000, ‘2012-04-23‘),
(2, ‘李四‘, ‘男‘, 27, 4500, ‘2013-05-23‘),
(3, ‘王五‘, ‘男‘, 23, 4700, ‘2012-04-21‘),
(4, ‘子龙‘, ‘男‘, 19, 3800, ‘2011-03-04‘),
(5, ‘李白‘, ‘男‘, 15, 6200, ‘2015-09-09‘),
(6, ‘刘备‘, ‘男‘, 28, 2500, ‘2016-02-11‘),
(7, ‘吕布‘, ‘男‘, 21, 6000, ‘2010-10-18‘),
(8, ‘尚香‘, ‘女‘, 16, 4500, ‘2011-09-26‘),
(9, ‘小乔‘, ‘女‘, 15, null, ‘2013-07-05‘),
(10, ‘大乔‘, ‘女‘, 16, 5000, ‘2017-09-01‘);

常用的运算符:
1: 等于( = )
    select * from employee where sal = 3800;
    select * from employee where sal = null;     --这里查询不到为null的数据

2: 等于( <=> )
    select * from employee where sal <=> 3800;
    select * from employee where sal <=> null;   --这里可以查询到为null的数据

3: is判断(null)
    select * from employee where sal is null;
    select * from employee where sal is not null;

4: null值判断还可以使用isnull();
    select * from employee where isnull(sal);
    select * from employee where !isnull(sal);

5: 在区间(between)内  between min and max  ps:这里是一个闭区间
    select * from employee where sal between 4500 and 5000;

6: 不在区间内
    select * from employee where sal not between 4500 and 5000;  --null不为包括进去

7: and 和 or
    select * from employee where sal not between 4500 and 5000 or sal is null;
    select * from employee where sal = 4500 and emp_sex = ‘女‘;

8: 小于(<), 大于(>), 小于等于(<=), 大于等于(>=)
    select * from employee where sal >= 4500;
***************************************************************************************************************

数学函数
1: rand();
    select rand() from dual;   --dual是一个伪表
    select 1+1 from dual;
    select rand();   --可以简写

2: least(value1, value2, ...) 返回最小值
    select least(54,76,4,65,76,87,87,56,65,654,45,23,1,76);
    select least(54,76,4,65,76,87,87,56,65,654,45,23,1,76) as min_value;   --列名可以起一个别名

3: greatest(value1, value2, ...) 返回最大值
    select greatest(54,76,4,65,76,87,87,56,65,654,45,23,1,76);

4: round(M, D); 返回M的四舍五入的值, D表示要保留几们小数,默认值是0
    select round(1.69);
    select round(1.69, 1);

5: abs() 绝对值
    select 5-10;
    select abs(5-10);
***************************************************************************************************************

汇总函数
1: avg();
    select * from employee where sal >= 6000;
    select avg(sal) from employee where sal >= 6000;

2: count()
    select count(*) from employee;
    select count(emp_name) from employee;
    select count(sal) from employee;      --打印9 这里会忽略null值
    select count(*) from employee where sal >= 4000;
    select count(*) from employee where sal <= 4000 or sal is null;

3: sum()
    select sum(sal) from employee where sal >= 6000;

4: min()
    select min(sal) from employee;

5: max()
    select max(sal) from employee;
***************************************************************************************************************

日期函数
1: 获取当前的日期时间
    select now(), sysdate(), current_timestamp();
    select now(6), sysdate(6), current_timestamp(6);
    ps: now(), current_timestamp();没有区别, 表示sql开始执行时的时间
        sysdate()表示这个函数开始时间

2: 获取当前日期
    select curdate();   --只有年月日

3: 获取当前时间
    select curtime();   --只有时分秒

4: 日期的加运算date_add     
    select history, date_add(history, interval ‘1 12:10‘ day_minute) from employee;   --date_add(history, interval ‘1 12:10‘ day_minute)
    select history, date_add(history, interval ‘1-1‘ year_month) from employee;       --date_add(history, interval ‘1-1‘ year_month)
    select history, date_add(history, interval ‘1‘ second) from employee;             --date_add(history, interval ‘1‘ second)

5: 日期的减运算data_sub
    select history, date_sub(history, interval ‘1-1‘ year_month) from employee;

6: 计算日期差
    select history, sysdate(), datediff(sysdate(), history) from employee;     --以天数来表示

7: 获取日期的指定部分(把日期转换为指定的格式)  date_format()
    select history, date_format(history, ‘%Y年%m月%d号‘) from employee;
    select history, date_format(history, ‘%d号‘) from employee;
    select history, date_format(history, ‘%Y年%m月%d号 %H时%i分%s秒‘) from employee;

8: 计算出一个日期是星期几
    select history, dayname(history) from employee;

9: 中文日期字符串转换日期str_to_date()
    insert into employee values(11, ‘张飞‘, ‘男‘, 22, 3000, ‘2017年02月01号‘);   --报错
    insert into employee values(11, ‘张飞‘, ‘男‘, 22, 3000, str_to_date(‘2017年02月01号‘, ‘%Y年%m月%d号 %H时%i分%s秒‘));

insert into employee values(12, ‘二哥‘, ‘男‘, 22, 3000, str_to_date(‘2017年02月01号 23时02分02秒‘, ‘%Y年%m月%d号 %H时%i分%s秒‘));
    insert into employee values(12, ‘二哥‘, ‘男‘, 22, 3000, str_to_date(‘2017年02月01号 11时02分02秒‘, ‘%Y年%m月%d号 %h时%i分%s秒‘));
    ps: 如果是h则表示12小制, 如果是大H则表示24小明制;

字符串函数
1: left(str, len) 返回字符串str的左端len个字符
    select left(‘abcdefg‘, 5);
 
2: length()
    select length(‘abcdefg‘);

3: lower(str) 返回小写的字符串str
    select lower(‘HELLO‘);

4: substring() 取子字符串, 第二个参数是截取的起始位置, 第三个参数是要截取的长度
    select substring(‘helloworld‘,2,3);

5: concat() 字符串拼接
    select concat(emp_name, ‘员工‘) from employee;

6: replace(替换
    select replace(emp_name, ‘李‘, ‘老‘) from employee where emp_name = ‘李四‘;

时间: 2024-08-07 00:07:35

Mysql运算符与函数(胖胖老师)的相关文章

mysql 运算符和函数

运算符: 算术运算符:+-*%/ 比较运算符:>< >= <= = <>(!=)  is(not)null  between.... and  (not)in like _ 一个字符, %零个或者多个字符 逻辑运算符: AND or not 数值函数: ceil(),floor(),round(),truncate(),mod() 字符函数: concat(s1,s2....) concat_ws(c,s1,s2....) lower(s) upper(s) lengt

Mysql单表查询(胖胖老师)

数据准备drop table if exists class;create table class(    class_no int(2) unsigned zerofill primary key auto_increment comment '班级编号',    class_name varchar(30) not null comment '班级名称');insert into class values(1, '培优班');insert into class values(2, '普通班'

跟王老师学MySQL:集合函数

跟王老师学MySQL:集合函数 主讲教师:王少华   QQ群号:483773664 学习内容 COUNT().SUM().AVG().MAX()和MIN()四个集合函数的使用 集合函数包括COUNT().SUM().AVG().MAX()和MIN(). 一.count() (一)简介 COUNT()函数用来统计记录的条数. (二)举例 使用count()函数统计employee表的记录数 1 SELECT  COUNT(*)  FROM  employee ; 二.SUM()函数 (一)简介 S

MySQL学习18:运算符与函数之数值运算符和函数、比较运算符和函数、日期时 间函数

数值运算符和函数 常见的数值函数下面几个: (1)数值运算符 MySQL数据库常见的数值运算符有:+.-.*...%等等.这里我们就不再一一列举,只是来看两个例子: SELECT 3+4; SELECT 3%4; (2)进一取整和舍一取整 SELECT CEIL(3.01); SELECT FLOOR(3.99); (3)整数除法 SELECT 3/4; SELECT 3 DIV 4; (4)取余数(取模) SELECT 5 % 3; SELECT 5 MOD 3; (5)幂运算 SELECT

MYSQL数值运算符和函数用法

mysql也有数值运算,那么列出常见的函数 ceil() div() floor() mod() power() round() truncate()等等,具体说说MYSQL数值运算符和函数用法. 1,ceil select ceil() 进一取整 2,div select div() 整除除法 3,floor 舍一取整 4,mod 取余数 5,power 幂运算 6,round 四舍五入 7,truncate 数字截取 以上就是常见的数字运算 文章来自 www.huthon.cn 原文地址:h

MYSQL常见运算符和函数

MYSQL常见运算符和函数[重要] 字符函数 (1)CONCAT():字符连接 SELECT CONCAT('IMOOC','-','MySQL');//IMOOC-MySQL SELECT CONCAT (first_name,last_name) AS fullname FROM test; (2)CONCAT_WS():使用指定的分隔符进行字符连接,(第一个位置指定分隔符,后面的为分割的内容) SELECT CONCAT_WS('%','abc','def'); //第一个是指定的分隔符:

MySQL学习17:运算符与函数之字符函数

MySQL字符函数 MySQL数据库中常用的字符函数有下面几个: (1)字符连接 首先创建一个名字为imooc的数据库,然后再使用CONCAT()字符连接函数进行查询: CREATE DATABASE imooc; SELECT CONCAT('imooc','MySQL'); SELECT CONCAT('imooc','-','MySQL'); 前期数据准备 CREATE TABLE test( first_name VARCHAR(20), last_name VARCHAR(10) );

MySQL日期时间函数大全(转)

MySQL日期时间函数大全 DAYOFWEEK(date)  返回日期date是星期几(1=星期天,2=星期一,……7=星期六,ODBC标准)mysql> select DAYOFWEEK('1998-02-03');  -> 3 WEEKDAY(date)  返回日期date是星期几(0=星期一,1=星期二,……6= 星期天). mysql> select WEEKDAY('1997-10-04 22:23:00');  -> 5 mysql> select WEEKDAY

【转】MySQL日期时间函数大全

MySQL日期时间函数大全 1.DAYOFWEEK(date)  返回日期date是星期几(1=星期天,2=星期一,……7=星期六,ODBC标准)mysql> select DAYOFWEEK('1998-02-03');  -> 3 2.WEEKDAY(date)  返回日期date是星期几(0=星期一,1=星期二,……6= 星期天). mysql> select WEEKDAY('1997-10-04 22:23:00');  -> 5 mysql> select WEE