表关联关系:

-- 内联接
SELECT * FROM m INNER JOIN n ON m.id = n.id;
-- 左外联接
SELECT * FROM m LEFT JOIN n ON m.id = n.id;
-- 右外联接
SELECT * FROM m RIGHT JOIN n ON m.id = n.id;
-- 交叉联接(基本禁止写法,除非特殊情况)
SELECT * FROM m CROSS JOIN n; -- 标准写法
SELECT * FROM m, n;
-- 要求UNION ALL 上下ssql字段要一致,将上下sql的记录拼在一起。
-- union 会过滤重复记录,union all 不会过滤。
SELECT id,name FROM m
UNION ALL
SELECT id,name FROM n;

常用函数:

-- 聚合函数(字段取别名可以省略 AS)
SELECT count(1) AS counts FROM XXX; -- 查询记录条数
SELECT sum(age) AS sumAge FROM XXX; -- 总和(全部记录age字段的和)
SELECT avg(age) AS avgAge FROM XXX; -- 平均值(全部记录age字段的平均值)
SELECT max(age) AS maxAge FROM XXX; -- 最大值(全部记录age字段的最大值)
SELECT min(age) AS minAge FROM XXX; -- 最小值(全部记录age字段的最小值)
-- 实际聚合函数使用场景(按照“字段” 分组,聚合函数可以按照分组聚合),having 可以增加条件去掉不需要的分组。
select count(1) from XXX GROUP BY 字段 HAVING 条件(比如字段=1) -- 数学函数
SELECT abs(-5); -- 绝对值
SELECT bin(15), oct(15), hex(15); -- 二进制,八进制,十六进制
SELECT pi(); -- 圆周率3.141593
SELECT ceil(5.5); -- 大于x的最小整数值6
SELECT floor(5.5); -- 小于x的最大整数值5
SELECT greatest(3,1,4,1,5,9,2,6); -- 返回集合中最大的值9
SELECT least(3,1,4,1,5,9,2,6); -- 返回集合中最小的值1
SELECT mod(5,3); -- 余数2
SELECT rand(); -- 返回0到1内的随机小数,每次不一样
SELECT rand(4); -- 提供一个参数(种子)使RAND()随机数生成器生成一个指定的值。
SELECT round(1415.1415); -- 四舍五入1415
SELECT round(1415.1415, 3); -- 四舍五入三位数1415.142
SELECT round(1415.1415, -1); -- 四舍五入整数位数1420
SELECT truncate(1415.1415, 3); -- 截短为3位小数1415.141
SELECT truncate(1415.1415, -1); -- 截短为-1位小数1410
SELECT sign(-5); -- 符号的值负数-1
SELECT sign(5); -- 符号的值正数1
SELECT sqrt(9); -- 平方根3
-- 字符串函数
SELECT concat('a', 'p', 'p', 'le'); -- 连接字符串-apple
SELECT concat_ws(',', 'a', 'p', 'p', 'le'); -- 连接用','分割字符串-a,p,p,le
SELECT insert('chinese', 3, 2, 'IN'); -- 将字符串'chinese'从3位置开始的2个字符替换为'IN'-chINese
SELECT left('chinese', 4); -- 返回字符串'chinese'左边的4个字符-chin
SELECT right('chinese', 3); -- 返回字符串'chinese'右边的3个字符-ese
SELECT substring('chinese', 3); -- 返回字符串'chinese'第三个字符之后的子字符串-inese
SELECT substring('chinese', -3); -- 返回字符串'chinese'倒数第三个字符之后的子字符串-ese
SELECT substring('chinese', 3, 2); -- 返回字符串'chinese'第三个字符之后的两个字符-in
SELECT trim(' chinese '); -- 切割字符串' chinese '两边的空字符-'chinese'
SELECT ltrim(' chinese '); -- 切割字符串' chinese '两边的空字符-'chinese '
SELECT rtrim(' chinese '); -- 切割字符串' chinese '两边的空字符-' chinese'
SELECT repeat('boy', 3); -- 重复字符'boy'三次-'boyboyboy'
SELECT reverse('chinese'); -- 反向排序-'esenihc'
SELECT length('chinese'); -- 返回字符串的长度-7
SELECT upper('chINese'), lower('chINese'); -- 大写小写 CHINESE chinese
SELECT ucase('chINese'), lcase('chINese'); -- 大写小写 CHINESE chinese
SELECT position('i' IN 'chinese'); -- 返回'i'在'chinese'的第一个位置-3
SELECT position('e' IN 'chinese'); -- 返回'i'在'chinese'的第一个位置-5
SELECT strcmp('abc', 'abd'); -- 比较字符串,第一个参数小于第二个返回负数- -1
SELECT strcmp('abc', 'abb'); -- 比较字符串,第一个参数大于第二个返回正数- 1
-- 时间函数
SELECT current_date, current_time, now(); -- 2018-01-13 12:33:43 2018-01-13 12:33:43
SELECT hour(current_time), minute(current_time), second(current_time); -- 12 31 34
SELECT year(current_date), month(current_date), week(current_date); -- 2018 1 1
SELECT quarter(current_date); --
SELECT monthname(current_date), dayname(current_date); -- January Saturday
SELECT dayofweek(current_date), dayofmonth(current_date), dayofyear(current_date); -- 7 13 13
-- 控制流函数
SELECT if(3>2, 't', 'f'), if(3<2, 't', 'f'); -- t f
SELECT ifnull(NULL, 't'), ifnull(2, 't'); -- t 2
SELECT isnull(1), isnull(1/0); -- 0 1 是null返回1,不是null返回0
SELECT nullif('a', 'a'), nullif('a', 'b'); -- null a 参数相同或成立返回null,不同或不成立则返回第一个参数
SELECT CASE 2
WHEN 1 THEN 'first'
WHEN 2 THEN 'second'
WHEN 3 THEN 'third'
ELSE 'other'
END ; -- second

常用系统表:

-- 查看数据库实例信息,“schema_name”数据库名称条件。
SELECT * from information_schema.`SCHEMATA` where schema_name = 'work_db';
-- 查看数据库表信息,“table_schema”数据库名称条件。
SELECT * from information_schema.`TABLES` where table_schema = 'work_db';
-- 查看数据库表列的信息,“table_schema”数据库名称条件,“table_name”查询表的条件。
SELECT * from information_schema.`COLUMNS` where table_schema = 'work_db' and table_name = 'operator';
-- 查看数据库表索引的信息,“table_schema”数据库名称条件,“table_name”查询表的条件。
SELECT * from information_schema.`STATISTICS` where table_schema = 'work_db' and table_name = 'operator';

其他信息:

-- 系统信息函数
SELECT database(); -- 当前数据库名-test
SELECT connection_id(); -- 当前用户id-306
SELECT user(); -- 当前用户-root@localhost
SELECT version(); -- 当前mysql版本
SELECT found_rows(); -- 返回上次查询的检索行数

参考:https://blog.csdn.net/c361604199/article/details/79479398

《MySQL数据库》常用语法(二)的更多相关文章

  1. MySQl数据库常用的DOS命令

    MySQl数据库常用的DOS命令.. 这是第一部分.. 数据库的连接信息:jdbc:mysql://localhost:3306/shxtcom.mysql.jdbc.Driver /*jdbc:sq ...

  2. MySQL 数据库常用命令小结

    MySQL 数据库常用命令 1.MySQL常用命令 create database name; 创建数据库 use databasename; 选择数据库 drop database name 直接删 ...

  3. DBA必备:MySQL数据库常用操作和技巧

    DBA必备:MySQL数据库常用操作和技巧 2011-02-25 15:31 kaduo it168 字号:T | T MySQL数据库可以说是DBA们最常见和常用的数据库之一,为了方便大家使用,老M ...

  4. mysql数据库常用语句

    关于mysql数据库常用命令的整理: 一:对于数据库的操作 show databases;显示当前用户下所有的数据库名称 use database_name;进入当前数据库 create databa ...

  5. Mysql数据库常用的命令 数据备份 恢复 远程

    远程数据库 格式: mysql -h主机地址 -u用户名 -p用户密码数据库 mysql -h 42.51.150.68 -u yang -p discuz mysql设置密码 mysql>us ...

  6. Mysql数据库常用分库和分表方式

    http://blog.csdn.net/clevercode/article/details/50877580 1 分库 1.1 按照功能分库 按照功能进行分库.常见的分成6大库:    1 用户类 ...

  7. java数据库 JDBC操作MySQL数据库常用API 部门表和员工表 创建表 添加数据 查询数据

    package com.swift.department; import java.sql.Connection; import java.sql.PreparedStatement; import ...

  8. 【码上开心】Windows环境mysql数据库使用(二)skip-grant-tables 与用户名密码修改

    skip-grant-tables #跳过数据库权限验证 我们安装MySql 设置my.ini配置文件的时候,常常会在my.ini中添加 skip-grant-tables ,这时接数据库可以使用任意 ...

  9. Mysql数据库常用操作语句大全

    零.用户管理: 1.新建用户: >CREATE USER name IDENTIFIED BY 'ssapdrow'; 2.更改密码: >SET PASSWORD FOR name=PAS ...

  10. MySQL数据库常用函数

    一.数学函数 数学函数主要用于处理数字,包括整型.浮点数等. ABS(x) 返回x的绝对值 不区分大小写 SELECT ABS(-1) -- 返回1 CEIL(x),CEILING(x) 返回大于或等 ...

随机推荐

  1. 扛把子组final week 1/1 Scrum立会报告+燃尽图 01

    此作业的要求参见http://edu.cnblogs.com/campus/nenu/2019fall/homework/10065 一.小组情况 队名:扛把子 组长:孙晓宇 组员:宋晓丽 梁梦瑶 韩 ...

  2. springboot整合netty的多种方式

    netty作为一个高性能的io框架,是非好用的一个技术框架, Netty 是一个基于NIO的客户.服务器端编程框架,使用Netty 可以确保你快速和简单的开发出一个网络应用,例如实现了某种协议的客户. ...

  3. Linux I/O复用 —— epoll 部分源码剖析

    epoll 相关的系统调用有以下三个,这里简述下当调用对应函数后,内核的具体实现 epoll_creat( ) 在内核注册文件系统 eventpollfs,挂载此文件系统 (linux一切皆文件,便于 ...

  4. 【python测试开发栈】—python内存管理机制(二)—垃圾回收

    在上一篇文章中(python 内存管理机制-引用计数)中,我们介绍了python内存管理机制中的引用计数,python正是通过它来有效的管理内存.今天来介绍python的垃圾回收,其主要策略是引用计数 ...

  5. windows安装Pytorch报错:from torch._C import * ImportError: DLL load failed: 找不到指定的模块”解决方案

    问题描述 python环境下安装cpu版本pytorch,安装成功,但是导入出错. 报错如下 解决方法 参考博客,大家解决方法大概有:升级numpy.添加.dll文件到环境变量,均没有成功.本地pyt ...

  6. 异常:java.lang.RuntimeException: Canvas: trying to draw too large(161740800bytes) bitmap

    现象 今天做一个安卓项目的时候,我使用了10张图片,这10张图片都是放在了drawable目录下. 根据这个错误,我在网上寻找解决问题的方案,然后我放在了mipmap-xxhdpi下结果可以运行. 但 ...

  7. 经典sql面试题(学生表_课程表_成绩表_教师表)

    转载:https://www.cnblogs.com/qixuejia/p/3637735.html 表架构 Student(S#,Sname,Sage,Ssex) 学生表 Course(C#,Cna ...

  8. Web渗透测试流程

    什么是渗透测试? 渗透测试 (penetration test)并没有一个标准的定义,国外一些安全组织达成共识的通用说法是:渗透测试是通过模拟恶意黑客的攻击方法,来评估计算机网络系统安全的一种评估方法 ...

  9. 【JavaEE】之MyBatis插入数据后获取自增主键

    很多时候,我们都需要在插入一条数据后回过头来获取到这条数据在数据表中的自增主键,便于后续操作.针对这个问题,有两种解决方案: 先插入,后查询.我们可以先插入一条数据,然后根据插入的数据的各个字段值,再 ...

  10. SpringCloud Alibaba微服务实战三 - 服务调用

    导读:通过前面两篇文章我们准备好了微服务的基础环境并让accout-service 和 product-service对外提供了增删改查的能力,本篇我们的内容是让order-service作为消费者远 ...