Mysql查询数据库 整理
一、 查询数据:
查询所有列:SELECT * FROM student;
查询指定列:SELECT id,NAME,gender FROM student;
格式:select字段名, 字段名, 字段名 from 表名
查询时添加常量列:
在查询xxx表时添加一个班级列,内容为“xxx”
SELECT id,NAME,gender,age,'xxx' AS '年级' FROM xxx;
查询时合并列:
需求: 查询每个学生的servlet和jsp的总成绩
SELECT id,NAME,(servlet+jsp) AS '总成绩' FROM student;
注意:合并列只能合并数值类型的字段
SELECT id,(NAME+servlet) FROM student;
查询时去除重复记录:
需求: 查询学生的性别 男 女
SELECT DISTINCT gender FROM student;
另一种语法
SELECT DISTINCT(gender) FROM student;
条件查询(where):
1) 逻辑条件: and(与) or(或)
a) 需求: 查询id为2,且姓名为李四的学生
SELECT * FROM student WHERE id=2 AND NAME='李四'; -- 交集
b) 需求: 查询id为2,或姓名为张三的学生
SELECT * FROM student WHERE id=2 OR NAME='张三'; -- 并集
2) 比较条件: > < >= <= = <>(不等于) between and (等价于>= 且 <=)
a) 需求: 查询servlet成绩大于70分的学生
SELECT * FROM student WHERE servlet>70;
b) 需求: 查询jsp成绩大于等于75,且小于等于90分的学生
a) SELECT * FROM student WHERE jsp>=75 AND jsp<=90;
另一个语法
b) SELECT * FROM student WHERE jsp BETWEEN 75 AND 90; -- (包前包后)
3) 判空条件(null 空字符串): is null / is not null / ='' / <>''
a) 需求: 查询地址为空的学生(包括null和空字符串)
null vs 空字符串
null:表示没有值
空字符串:有值的,但是值是空字符串
b) 判断null
SELECT * FROM student WHERE address IS NULL ;
c) 判断空字符串
i. SELECT * FROM student WHERE address='';
ii. SELECT * FROM student WHERE address IS NULL OR address=''; -- (包括null和空字符串)
d) 需求: 查询有地址的学生(不包括null和空字符串)
SELECT * FROM student WHERE address IS NOT NULL AND address<>'';
4) 模糊条件: like
通常使用以下替换标记:
% : 表示任意个字符
_ : 表示一个字符
i. 需求: 查询姓‘张’的学生
SELECT * FROM student WHERE NAME LIKE '李%';
ii. 需求: 查询姓‘李’,且姓名只有两个字的学生
SELECT * FROM student WHERE NAME LIKE '李_';
聚合查询
常用的聚合函数:sum() avg() max() min() count()/*记录*/
求和:
Select sum(字段名) from 表名
求平均:
Select avg(字段名) from 表名
最大值:
Select sum(字段名) from 表名
最小值:
Select sum(字段名) from 表名
统计表记录数(常用):
Select count(*) from 表名
分页查询(limit 起始行,查询几行)
分页查询当前页的数据的sql:
公式:
SELECT * FROM student LIMIT (当前页-1)*每页显示多少条,每页显示多少条;
查询第x,x条记录
查询排序(order by)
语法: order by 字段 asc正序/desc倒序
asc: 顺序,正序。数值:递增,字母:自然顺序(a-z)
SELECT * FROM student ORDER BY id ASC;
格式:select * from 表名order by 字段名 desc
desc: 倒序,反序。数值:递减,字母:自然反序(z-a)
SELECT * FROM student ORDER BY id DESC;
格式:select * from 表名 order by 字段名 desc
分组查询(group by)
SELECT gender,COUNT(*) FROM student GROUP BY gender;
格式:select 字段名,count(*) from 表名group by
分组查询后筛选(group by having)
筛选出人数大于2的记录
SELECT gender,COUNT(*) FROM student GROUP BY gender HAVING COUNT(*)>2;
格式:select 字段名,count(*或者字段名) from 表名 group by 字段名 having count(*)>值
Mysql查询数据库 整理的更多相关文章
- mysql查询数据库大小和表
每个mysql都有一个库information_schema,里面有一张表TABLES存储了所有数据库表的信息,因此,可以从这张表中查看数据库大小和表大小 查询数据库大小 ,),'GB') as da ...
- mysql 查询数据库或某张表有多大(字节)
转载:https://www.cnblogs.com/diandiandidi/p/5582309.html 1.要查询表所占的容量,就是把表的数据和索引加起来就可以了 select sum(DATA ...
- [功能集锦] 002 - mysql查询数据库字典+导出+样式一键整合至excel
写在前面: 因为工作时候经常遇到半路接手项目的情况,由于年代久远,数据库字典这块经常缺失.故写此篇,以便复用,也希望对大家有点帮助. 随笔内容不高级,如有不妥,不吝指正. 20190730-加了一些简 ...
- MySql 查询数据库中所有表名
查询数据库中所有表名select table_name from information_schema.tables where table_schema='csdb' and table_type= ...
- MYSQL查询数据库表索引的硬盘空间占用
查询数据库的占用 SELECT CONCAT(ROUND(SUM(index_length)/(1024*1024), 2), ' MB') AS 'Total Index Size' , CONCA ...
- mysql查询数据库中包含某字段(列名)的所有表
SELECT TABLE_NAME '表名',TABLE_SCHEMA '数据库名',ORDINAL_POSITION '顺序',COLUMN_NAME '字段',DATA_TYPE '类型' ,CH ...
- 【MySQL】MySQL查询数据库各表的行数
#倒序查询数据库[各表记录数] use information_schema; select table_name,table_rows from tables where TABLE_SCHEMA ...
- MySql 查询数据库中所有表名以及对比分布式库中字段和表的不同
查询数据库中所有表名select table_name from information_schema.tables where table_schema='数据库名' and table_type= ...
- MySQL查询数据库中表名或字段名
查询数据库中所有表名 select table_name from information_schema.tables where table_schema='csdb' and table_type ...
随机推荐
- 使用Windows任务计划程序运行Windows PowerShell脚本
创建计划任务以运行PowerShell脚本 我需要创建一个计划任务来运行Windows PowerShell脚本的第一件事是我将执行的命令行.找到这个的简单方法是使用Run 命令.有时,我需要知道什么 ...
- HDU 1074 Doing Homework(经典状压dp)
题目链接 Doing Homework Ignatius has just come back school from the 30th ACM/ICPC. Now he has a ...
- 【C/C++】c文件重点总结
c文件重点知识总结 程序文件数据文件--->分文本文件(ASCII文件)和映像文件(二进制文件) .区分是用记事本打开后能否看懂. 用二进制文件读写花费时间少,因为用文本文件需要有一个转换的过程 ...
- python----函数的动态传参
函数的动态传参 *args 将所有的实参的位置参数聚合到一个元组,并将这个元组赋值给args 有些时候,对于函数,传入的实参数量可能是不固定的,也就是动态的,这个时候我们就需要用到函数的动态传参.下面 ...
- H5 history.pushState 在微信内修改url后点击用safari打开/复制链接是修改之前的页面
解决方案:url参数增加随机参数 function wxRefresh() { var replaceQueryParam = (param, newval, search) => { var ...
- Java中的getGenericSuperclass的基本用法
通过getGenericSuperclass方法可以获取当前对象的直接超类的Type,使用该方法可以获取到泛型T的具体类型 package cn.tzz.lang.clazz; public clas ...
- BZOJ3144[Hnoi2013]切糕——最小割
题目描述 输入 第一行是三个正整数P,Q,R,表示切糕的长P. 宽Q.高R.第二行有一个非负整数D,表示光滑性要求.接下来是R个P行Q列的矩阵,第z个 矩阵的第x行第y列是v(x,y,z) (1≤x≤ ...
- 洛谷P1501 Tree II
LCT 还是LCT的板子,下放标记和那道线段树2一样,先放乘..之前用char忘记getchar,调了好久... 注意开long long!! #include <bits/stdc++.h&g ...
- 【XSY2779】最小表示串 KMP DP polya定理
题目描述 给你一个字符串\(s\),问你有多少个串是最小表示串且字典序\(\leq s\) \(|s|\leq 1000\) 题解 先把\(s\)变成比\(s\)小的最大的最小表示串.方法是从后枚举每 ...
- MT【264】分式变形
已知$x,y>0,\dfrac{1}{x}+\dfrac{2}{y}=1$,求$\dfrac{1}{x+1}+\dfrac{2}{y+1}$的最大值____ 解答:令$a=\dfrac{1}{x ...