sql基础汇总

  

--根据函数别名排序
--排序规则,默认是升序
sleect LENGTH(NAME) nameLength from user ORDER BY nameLength DESC --特殊符号
特殊符号<=> 安全等于可以比较null和数值,正常比较null通过is null 和is not null 数值是 = <> !=和<>相同,in(1,2)是1或者2 between 1 and 10 是1~10的所有整数 IFNULL(num,0) num不为null 返回num否则返回0 --两个以上字段排序,不写默认升序 asc
SELECT * FROM user ORDER BY age DESC, salary ASC;
--查询年龄在20-40之间
SELECT * FROM user WHERE age BETWEEN 20 AND 40 ORDER BY age DESC
--查询年龄在20-40之间
SELECT * FROM user WHERE age NOT BETWEEN 20 AND 40 ORDER BY age DESC
--模糊查询
SELECT * FROM user WHERE name LIKE "%a%" ORDER BY LENGTH(name) DESC, phone ASC --函数
--单行函数 concat()字符串拼接、ifnull、length()
--分组函数
--分组函数又称为统计函数、聚合函数、组函数 --拼接字符串
SELECT CONTACT(name,"--",age) FROM user;
--大小写切换
SELECT UPPER(name),LOWER(type);
--截取字符串,下表从1开始,从第2截取到末尾
SELECT SUBSTRING("ABCDEFG",2);
--截取(1,2),从第一位开始,截取两个字符
SELECT SUBSTRING("ABCDEFG",1,2);
--返回子串第一次出现的索引
SELECT INSTR("ABCDEF",'DE')
--去除空格
SELECT TRIM(" DDD ");
--去除a,只能去除字符串的前后,不能去除中间
SELECT TRIM('a' FROM "AaaaaBCDEFDALKDFJAaaaaaaaa");
--指定长度的左填充,格式 2222222AAA
SELECT LPAD("AAA",10,"2");
--右填充
SELECT LPAD("AAA",10,"2");
--字符串替换,将A替换为UUU
SELECT REPLACE("111AAA222","A","UUU")
--取整数函数,四舍五入
SELECT ROUND(1.2);
--保留两位小数
SELECT ROUND(1.556,2);
--向上取整,返回大约等于该值的最小整数
SELECT CEIL(1.02);
--向下取整,返回小于等于该值的最大整数
SELECT FLOOR(1.2);
--阶段,保留小数位数
--SELECT TRUNCATE(1.34,1);
--取余是1
SELECT MOD(10,3); --日期+时间
SELECT NOW();
--日期
SELECT CURDATE();
--时间
SELECT CURTIME();
--获取年份
SELECT YEAR(NOW());
--月
SELECT MONTH(NOW());
--英文月份名称
SELECT MONTHNAME(NEWO());
--字符串转日期
SELECT STR_TO_DATE("1994-3-9","%Y-%C-%D");
--日期转字符串
SELECT DATE_FORMAT(NOW(),"%Y年-%m月-%d日");
--查询两个日期 相差天数
SELECT DATEDIFF(); --流程控制
--大于,大,否则小
SELECT IF(10>5,"大","小"); --case函数
SELECT salary,id
CASE id
when 30 THEN SALARY*1.3
WHEN 40 THEN SALARY*1.5 FROM user
SELECT salary,id 
CASE
when 条件1 THEN SALARY*1.3
WHEN 条件2 THEN SALARY*1.5 FROM user
--分组函数 ,用作统计
SELECT SUM(salary),AVG(salary),MIN(salary),MAX(salary),COUNT(salary) FROM user;
--查询部门最大工资和平均工资
SELECT AVG(salary),MAX(salary) FROM user where age is not null GROUP BY department;
--查询部门员工个数大于2,分组后的筛选用having
SELECT COUNT(*),department_id
FROM employees
GROUP BY department_id
HAVING COUNT(*)>2
--查询每个工种有奖金的员工的最高工资大于12000的
SELECT job_id,MAX(salary)
FROM employees
where reward is not null
group by job_id
having MAX(salary)>12000;
--查询每个领导编号>102的领导手下工资>5000的领导编号和最低工资
SELECT manage_id,MIN(salary)
FROM employees
GROUP BY manage_id
WHERE manage_id>102
HAVING MIN(salary)>5000;
--查询每个部门每个工种的平均工资,降序
SELECT job_id,department_id,AVG(salary) as avg
FROM employee
WHERE department_id is not null
GROUP BY job_id,department_id
HAVING avg>120000
ORDER BY agv DESC
--聚合函数通过HAVING筛选,不能用where
--查询工资和级别
select salary,grade
from user,grade
where selary between grade.low and grade.up --内链接 筛选条件放在where 连接条件放在on
select name,job
from user u inner join job j on u.id = j.id
where name like "%a%"; select a.name,b.id,c.type
from a inner join b on a.id=b.id inner join c on a.id=c.id
where a.name like "%a%"
group by a.name; --内连接是 显示交集,外连接,左是已左表为主表,显示全部主表

SQL 函数 排序 等基础操作 DDL DML DQL 用法和<> <=>等的更多相关文章

  1. SQL中的四种语言DDL,DML,DCL,TCL

    1.DDL(Data Definition Language)数据库定义语言statements are used to define the database structure or schema ...

  2. DCL,DDL,DML,DQL

    DCL(Data Control Language)是数据库控制语言. 是用来设置或更改数据库用户或角色权限的语句,包括(grant,deny,revoke等)语句. 在默认状态下,只有sysadmi ...

  3. [SQL] SQL学习笔记之基础操作

    1 SQL介绍 SQL 是用于访问和处理数据库的标准的计算机语言.关于SQL的具体介绍,我们通过回答如下三个问题来进行. SQL 是什么? SQL,指结构化查询语言,全称是 Structured Qu ...

  4. SQL语言:DDL/DML/DQL/DCL

    SQL (Structure Query Language)语言是数据库的核心语言. SQL 的发展是从1974年开始的,其发展过程如下: 1974年-----由Boyce和Chamberlin提出, ...

  5. MySql用statement实现DDL,DML,DQL的操作Demo

    Demo1 Connection connection=null; Statement stmt=null; int result=-1; try { Class.forName("com. ...

  6. 区别 |DCL |DDL |DML |DQL

    DCL(Data Control Language)数据控制语言: 用来设置或更改数据库用户或角色权限的语句,包括(grant,deny,revoke等)语句.这个比较少用到. 对于大多数人,在公司一 ...

  7. SQL操作数据——SQL组成,查询基础语法,where,Oracle常用函数等

    SQL组成 DML数据操作语言 DCL数据控制语言 DQL数据查询语言 DDL数据定义语言 查询基础语法 记录筛选 where 子句 记录筛选 where 子句 实例练习 实例练习 Select语句中 ...

  8. oracle(sql)基础篇系列(一)——基础select语句、常用sql函数、组函数、分组函数

        花点时间整理下sql基础,温故而知新.文章的demo来自oracle自带的dept,emp,salgrade三张表.解锁scott用户,使用scott用户登录就可以看到自带的表. #使用ora ...

  9. MySQL(一) -- MySQL学习路线、数据库的基础、关系型数据库、关键字说明、SQL、MySQL数据库、MySQL服务器对象、SQL的基本操作、库操作、表操作、数据操作、中文数据问题、 校对集问题、web乱码问题

    1 MySQL学习路线 基础阶段:MySQL数据库的基本操作(增删改查),以及一些高级操作(视图.触发器.函数.存储过程等). 优化阶段:如何提高数据库的效率,如索引,分表等. 部署阶段:如何搭建真实 ...

随机推荐

  1. 钉钉内网穿透工具在windows的使用。

    钉钉内网穿透工具在windows环境下使用 1.WIN+R,然后cmd,调出dos控制台 2.进入内网穿透程序ding.exe所在目录 3.执行 ./ding.exe -config=ding.cfg ...

  2. 美多商城后台MIS系统部署之Nginx配置

    先进入Nginx的配置文件中,进行配置. Nginx配置文件夹的区别: cd /etc/nginx/conf.d/   创建.conf后缀的文件 /etc/nginx/sites-enabled  创 ...

  3. Shell脚本命令汇总中

    一.换行 echo -e 可以通过\n编译换行 echo -n不换行,如果加入了\n,则会打出“\n”字符 #!/bin/bash echo -e "O\nK\n!" echo & ...

  4. 8.7-Day1T1

    题目大意: T组测试数据,每组测试数据给出一个n,求[0,n-1]所有逆元的和.(n可能不为质数) 题解: 我的想法: 求出每一个数的逆元,再相加.由于有n为质数的时候,所以,我将它分为两种情况:(1 ...

  5. string常用成员函数

    string常用成员函数 std::string::clear Clear string Erases the contents of the string, which becomes an emp ...

  6. 移动端适配rem为单位的rem.js及个别设备设置了大字体模式,导致页面变形的处理方式

    这段时间内,涉及到的都是移动端开发,说到移动端开发,我们就会思考到,目前分辨率的问题,如果用px为单位的话,在不同移动设备和不同分辨率下,页面的效果可能会有所不同,甚至导致页面变形.所以在次我们就用到 ...

  7. Django视图层、模板层

    过滤器方法 upper 大写方式输出 add 给value加上一个数值 capfirst 第一个字母大写 center 输出指定长度的字符串,把变量居中 cut 删除指定字符串 date 格式化日期 ...

  8. Spring 属性依赖注入

    1.1    属性依赖注入 依赖注入方式:手动装配 和 自动装配 手动装配:一般进行配置信息都采用手动 基于xml装配:构造方法.setter方法 基于注解装配: 自动装配:struts和spring ...

  9. Atcoder Beginner Contest151D(迷宫问题求任意两点最短路径的最大值,BFS)

    BFS可以求得最短路,DFS会找到从当前点到图中叶子结点的路径. #define HAVE_STRUCT_TIMESPEC #include<bits/stdc++.h> using na ...

  10. linux shell seq命令详解

    seq: squeue  是一个序列的缩写,主要用来输出序列化的东西 seq常见命令参数 用法:seq [选项]... 尾数 或:seq [选项]... 首数 尾数 或:seq [选项]... 首数 ...