百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

《MySQL必知必会》看这篇就够了

wptr33 2024-11-19 12:25 25 浏览

连接mysql

在terminal中连接mysql,输入以下指令:

USE crashhouses;
SHOW DATABASES:
SHOW TABLES
SHOW COLUMNS FROM customers;
SHOW STATUS

连接数据库

USE crashhouses;
SHOW DATABASES:
SHOW TABLES
SHOW COLUMNS FROM customers;
SHOW STATUS

SELECT,DISTINCT,LIMIT语句

SELECT name FROM products ORDER BY name;  --排序
SELECT name,id FROM products ORDER BY name,id; --选择多个列排序

--DESC关键字只应用与其前面的列名,不能部分使用DESC。
SELECT name FROM products ORDER BY name DESC,id; --指定降序

--LIMIT 必须位于ORDER BY 之后

ORDER BY语句

--ORDER BY 位于 WHERE 之后
SELECT name,id FROM products WHERE name = 'lucky' ORDER BY id; 
-- WHERE 的操作符有>,=,<,!=,BETWEEN等

-- NULL 空值检查
SELECT id FROM customers WHERE email IS NULL;

WHERE语句

SELECT id, price FROM products
WHERE id=1003 AND price<=10;

SELECT id, price FROM products
WHERE id=1003 OR id=1000;

-- 括号改变计算的次序
SELECT id, price FROM products
WHERE (id=1003 or id=1000) AND price<=10;

SELECT id, price FROM products
WHERE id IN(1003,1006);

SELECT id, price FROM products
WHERE id NOT IN(1003,1006);

AND, OR, IN, NOT操作符

-- '%'表示任何字符出现任意次数;'_'只匹配单个字符
SELECT name FROM products
WHERE name LIKE '_jet%';

LIKE 操作符

-- '%'表示任何字符出现任意次数;'_'只匹配单个字符
SELECT name FROM products
WHERE name LIKE '_jet%';

REGEXP

LIKE 匹配整个列,REGEXP在列值内匹配
具体规则参考正则式符号

SELECT name FROM products
WHERE name REGEXP '^jet.*';

SELECT id*2+1 AS new_id,
Concat(RTrim(name),'(',LTrim(country),')')
AS vend_title
FROM venders
ORDER BY name;

文本处理函数

函数直接作用于选中列

  • Upper(), Lower(), Locate(), Length()
  • Left(), Right(), LTrim(), RTrim()
  • Soundex(), SubString()

日期时间处理函数

具体的函数到用的时候再查找

数值处理函数

  • Abs(), Cos(), Exp(), Mod()
  • Pi(), Rand(), Sin(), Sqrt(), Tan()

聚集处理函数

  • AVG(), COUNT(), MAX(), MIN(), SUM()

GROUP BY 语句

  • GROUP BY 的时候,所有列一起计算
  • GROUP BY 子句包含任意数目的列
  • GROUP BY 子句列出的每个列必须是检索列或者有效的表达式(不能是聚集函数)。如果SELECT中使用表达式,则必须在GROUP BY 子句中使用相同的表达式,而不是别名
  • 除聚集计算语句外,SELECT中选中的每个列必须在GROUP BY 子句中给出。
  • NULL 作为一个分组返回
  • GROUP BY 子句中在 WHERE之后,ORDER BY之前。
SELECT id, name, COUNT(*) AS num_prods
FROM products
WHERE id>1001 AND id < 1003
GROUP BY id, name
ORDER BY id;

HAVING 语句

WHERE 过滤行,HAVING过滤组
HAVING 不使用别名

SELECT id, name, COUNT(*) AS num_prods
FROM products
WHERE id>1001 AND id < 1003
GROUP BY id, name
HAVING COUNT(*)>= 3
ORDER BY id;

SELECT子句顺序

顺序如下:SELECT,FROM, WHERE, GROUP BY, HAVING ,ORDER BY, LIMIT


使用子查询

可以将一个SELECT子句嵌套在另一个SELECT语句中。其中,列必须匹配,即具有相同的列数,可以使用多个列。

使用子查询不总是执行这种类型数据的最有效办法。可以使用连接表。

SELECT id FROM orders
WHERE num IN (	SELECT num FROM orderitems 
				WHERE id ='TNT2');

使用WHERE连接

SELECT vend_name, prod_name, prod_price FROM vendors ,products
WHERE vendors.vend_id = products.vend_id;

内部连接 INNER JOIN …ON

SELECT vend_name, prod_name, prod_price
FROM vendors INNER JOIN products
ON vendors.vend_id = products.vend_id;

联结多个表


使用表的别名

给使用的表起别名, 应用的时候运用别名。

使用不同类型的联结

自连接

SELECT p1.id,p1.name 
FROM products AS p1, products AS p2
WHERE p1.id=p2.id AND p2.id='DTNTR';

外部连接

LEFT INNER…ON, RIGHT INNER… ON


UNION 操作符

两个SELECT 语句间加上UNION

SELECT id FROM products WHERE id>1
UNION
SELECT id FROM products WHERE id<1;

包含或者取消重复的行

UNION ALL 返回所有匹配行,包含重复的行;默认UNION,重复的行会被取消


Match() Against() 全文本搜索

在建立TABLE的时候,FULLTEXT()的列就是为了进行全文本搜索;
Match()的值必须与FULLTEXT()定义中的相同;

SELECT note_text FROM productnotes
WHERE Match(note_text) Against('rabbit');

使用查询扩展 WITH QUERY EXPANSION

SELECT note_text FROM productnotes
WHERE Match(note_text) Against('rabbit')
WITH QUERY EXPANSION;

布尔文本搜索 IN BOOLEAN MODE

SELECT note_text FROM productnotes
WHERE Match(note_text) Against('rabbit' IN BOOLEAN MODE)

INSERT

// 插入多个行
INSERT INTO Customers(name,age)
VALUES('lucky','18'),
('Larry','23');
//插入检索出的数据
INSERT INTO Customers(name,age)
SELECT(name,age) FROM CustomersOld;

UPDATE

可用来更新或清空指定的列

UPDATE customers
SET name='lucky',age='18'
WHERE id=1000;
//删除指定的列
UPDATE customers
SET mail=NULL;

DELETE

可用来删除指定的行或删除所有行

DELETE FROM customets
WHERE id=10000;
//快速的删除所有行
TRUNCATE TABLE cus

相关推荐

HIVE 窗口函数详解(hive常用开窗函数)

什么是窗口函数窗口函数是SQL中一类特别的函数。和聚合函数相似,窗口函数的输入也是多行记录。不同的是,聚合函数的作用于由GROUPBY子句聚合的组,而窗口函数则作用于一个窗口,这里,窗口...

SQL高效使用20招:数据分析师必备技巧

基础优化技巧善用EXPLAIN分析执行计划EXPLAINSELECT*FROMordersWHEREorder_date>'2024-01-01';...

答记者问之 - Redis 的高效架构与应用模式解析

问:极客程序员你好,请帮我讲一讲redis答:redis主要涉及以下核心,我来一一揭幕Redis的高效架构与应用模式解析...

MySQL通过累计求新增(mysql新增表字段语句)

前两天的那篇内容《MySQL递归实现单列分列成多行》...

一文讲懂SQL窗口函数 大厂必考知识点

大家好,我是宁一。今天是我们的第24课:窗口函数。...

圣诞快乐:用GaussDB T 绘制一颗圣诞树,兼论高斯数据库语法兼容

转眼就是圣诞的节日,祝大家节日快乐。用GaussDBT(也就是GaussDB100)绘制一棵圣诞树,纯国产,更喜庆。话不多说,上图:SQL如下:SELECTCASEWHENENMOTE...

Minitab:功能强大的质量管理、统计分析及统计图形软件

一、Minitab简介Minitab软件是为质量改善、教育和研究应用领域提供统计软件和服务的先导,是全球领先的质量管理和六西格玛实施软件工具及持续质量改进的良好工具软件,她具有强大的功能和简易的可视化...

如何熟练使用SQL查询(如何熟练使用sql查询内容)

要熟练使用SQL查询(StructuredQueryLanguage),你需要系统地从语法入门,到实战练习,再到性能优化与多表查询的掌握。下面是一条循序渐进、实战驱动的学习路径:第一阶段:S...

SAP SE38如何在多个系统间同步代码

上一篇文章写了如何在多个系统之间同步开发对象:多套SAPERP之间一键同步ABAP开发内容,有兄弟问有没有简单办法同步SE38程序代码的,因为使用请求的方式同步代码有点小题大做了。...

Python | 垂直模态分解(phython垂直输出)

...

技术栈:刷了百道SQL题,还是不会用?你应该这样补短板

这是来自用户的提问,也是很多人遇到的困惑:...

mysql窗口函数为了解决更加复杂的问题

为了解决复杂问题的窗口函数我们先讲一下窗口函数是什么窗口和普通的函数作用相同在不同列上进行查询和返回比如我们有如下的表...

MariaDB开窗函数(开窗函数 mysql)

在使用GROUPBY子句时,总是需要将筛选的所有数据进行分组操作,它的分组作用域是整张表。分组以后,为每个组只返回一行。而使用基于窗口的操作,类似于分组,但却可以对这些"组"(即窗口...

一文掌握 DuckDB 时间序列分析:窗口函数实战详解

...

一篇文章搞定MySQL中的窗口函数(mysql常用的窗口函数)

我是孙斌,北理数学系毕业,分享数据分析相关知识,点击右上角“关注”,学习更多数据分析知识。在MySQL中,分组groupby一般和聚合函数连用,如groupby+sum,这样能够得到每个组的总和,...