MySQL---基本的查询语句与运算符介绍

本文介绍了MySQL的基本查询语句,包括SELECT用于选取字段,DISTINCT去除重复行,别名的设定,以及如何处理空值。还讲解了各种运算符的使用,如算术运算符、比较运算符、BETWEEN、IN、LIKE和正则表达式,并展示了WHERE子句和逻辑运算符在过滤数据中的应用。
摘要由CSDN通过智能技术生成

MySQL—基本的查询语句

基本的SELECT语句

SELECT  字段1 FROM 表明
SELECT employee_id,first_name,last_name,salary
FROM employees;
列的别名
  • 直接使用空格间隔
  • 利用 as 关键字命名别名
  • 双引号 设置别名
SELECT employee_id  emp_id,first_name as  fname,last_name "部门id",salary*12 "annual salary"
FROM employees;
去除重复行

DISTINCT

SELECT DISTINCT department_id
FROM employees;
空值参与运算

空值:null

null 并不等同与 0

空值参与运算:结果一定也为空值

SELECT employee_id,commission_pct,salary "月工资",salary*(1+commission_pct)*12 "年工资"
FROM employees;

引入IFNULL可以去除空值运算的效果

SELECT employee_id,commission_pct,salary "月工资",salary*(1+IFNULL(commission_pct,0))*12 "年工资"
FROM employees;
着重号 ``

必须保证你的字段没有和保留字、数据库系统或常见方法冲突。

如果坚持使用,在SQL语句中使用 ` ` 引起来。

SELECT * FROM `order`;
查询常数

所写的常数将在查询的一整列进行显示

SELECT 'ARCSOFT' as 'corp',employee_id,first_name,last_name,salary
FROM employees;
显示表结构

DESCRIBE + 表名:显示表中字段的详细信息

DESCRIBE employees;

DESC `order`;
过滤数据

WHERE条件,声明必须跟在FROM结构的后面

SELECT * 
FROM employees
WHERE department_id=90;

SELECT *
FROM employees
WHERE last_name='King' AND department_id=90;

运算符使用

算数运算符
  • / ,div
  • % ,mod

DUAL 为 伪表 ,mysql可以忽略

SQL语句中,+没有连接作用,就表示加法运算。此时,会将字符串转换为数值(隐式转换)

  • 一个整数类型的值对整数进行加法和减法操作,结果还是一个整数;
  • 一个整数类型的值对浮点数进行加法和减法操作,结果是一个浮点数;
  • 在Java中, + 的左右两边如果有字符串,那么表示字符串的拼接。但是在MySQL中 + 只表示数值相加。如果遇到非数值类型,先尝试转成数值,如果转失败,就按0计算。(注:MySQL 中字符串拼接要使用字符串函数CONCAT()实现)
  • 在数学运算中,0不能用作除数,在MySQL中,一个数除以0为NULL。
SELECT 100,100+0,100-0,100+50,50-25
From DUAL;

SELECT 100+'a';

SELECT 100+NULL;
SELECT employee_id,last_name,first_name
FROM employees
where employee_id%2=0
比较运算符

比较运算符用来对表达式左边的操作数和右边的操作数进行比较,比较的结果为真则返回1,比较的结果 为假则返回0,其他情况则返回NULL。

=使用

字符串中存在隐式转换,如果转换数值不成功,则看作0

  • 如果等号两边的值、字符串或表达式都为字符串,则MySQL会按照字符串进行比较,其比较的 是每个字符串中字符的ANSI编码是否相等。
  • 如果等号两边的值都是整数,则MySQL会按照整数来比较两个值的大小。
  • 如果等号两边的值一个是整数,另一个是字符串,则MySQL会将字符串转化为数字进行比较。
  • 如果等号两边的值、字符串或表达式中有一个为NULL,则比较结果为NULL。

<=>安全等于

安全等于运算符时,两边的操作数的值都为NULL时,返回的结果为1而不是NULL,其他返回结果与等于运算符相同。

可以处理带NULL的数据值

SELECT employee_id,last_name,first_name,commission_pct
FROM employees
where commission_pct IS NOT NULL;

SELECT employee_id,last_name,first_name,commission_pct
FROM employees
where commission_pct <=> NULL ;

LEAST() \ GREATEST()

SELECT LEAST('g','e','a'),GREATEST('g','e','a');

BETWEEN 条件下界 AND 条件上界

SELECT employee_id,last_name,first_name,commission_pct,salary
FROM employees
where salary>=6000 AND salary<=8000;


SELECT employee_id,last_name,first_name,commission_pct,salary
FROM employees
where salary BETWEEN 6000 AND 8000;


SELECT employee_id,last_name,first_name,commission_pct,salary
FROM employees
where salary NOT BETWEEN 6000 AND 8000;

IN (set)\ NOT IN (set)

IN运算符用于判断给定的值是否是IN列表中的一个值,如果是则返回1,否则返回0。如果给 定的值为NULL,或者IN列表中存在NULL,则结果为NULL。

SELECT employee_id,last_name,first_name,commission_pct,salary,department_id
FROM employees
where department_id in (10,20,30)

SELECT employee_id,last_name,first_name,commission_pct,salary,department_id
FROM employees
WHERE department_id NOT IN (10,20,30)

like 模糊查询

% 代表不确定个数的字符(0个 1个 多个)

SELECT employee_id,last_name,first_name,commission_pct,salary,department_id
FROM employees
where last_name like 'a%';

SELECT employee_id,last_name,first_name,commission_pct,salary,department_id
FROM employees
WHERE last_name LIKE '%a%' AND last_name LIKE '%e%';

SELECT employee_id,last_name,first_name,commission_pct,salary,department_id
FROM employees
WHERE last_name LIKE '%a%e%' OR  last_name LIKE '%e%a%';

-- 查找第二个字符为a的数据
SELECT employee_id,last_name,first_name,commission_pct,salary,department_id
FROM employees
WHERE last_name LIKE '_a%'

SELECT employee_id,last_name,first_name,commission_pct,salary,department_id
FROM employees
WHERE last_name LIKE '_\_a%';


#添加转义字符
SELECT employee_id,last_name,first_name,commission_pct,salary,department_id
FROM employees
WHERE last_name LIKE '_$_a%' ESCAPE '$';

正则表达式运算符

(1)‘^’匹配以该字符后面的字符开头的字符串。

(2)‘$’匹配以该字符前面的字符结尾的字符串。

(3)‘.’匹配任何一个单字符。

(4)“[…]”匹配在方括号内的任何字符。例如,“[abc]”匹配“a”或“b”或“c”。为了命名字符的范围,使用一 个‘-’。“[a-z]”匹配任何字母,而“[0-9]”匹配任何数字。

(5)‘’匹配零个或多个在它前面的字符。例如,“x”匹配任何数量的‘x’字符,“[0-9]”匹配任何数量的数字, 而“”匹配任何数量的任何字符。

逻辑运算符
  • NOT !
  • AND &&
  • OR ||
  • XOR 异或
SELECT employee_id,last_name,first_name,commission_pct,salary,department_id
FROM employees
WHERE department_id =50 XOR salary >6000;

位运算符

位运算符是在二进制数上进行计算的运算符。位运算符会先将操作数变成二进制数,然后进行位运算, 最后将计算结果从二进制变回十进制数。

  • & 位与
  • | 位或
  • ^ 位异或
  • ~ 位取反
  • 》位右移
  • 《 位左移
SELECT 12&5,12|5,12^5,~1,12>>1,12<<1;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值