#数据表的查询框架
select [all | distinct] select_list
from tb_name
[where 查询条件]
[group by <group_by_expression>]
[having <查询条件>]
order by <排序表达式> [asc|desc]
limit [<offset>,<row count>]
#关键字的用法
select 指定有查询返回的列
from 用于指定引用的列所在的表和视图
where 指定用于限制返回行的搜索条件
group by 用于根据字段对行分组
having 指定分组或聚合的搜索条件
order by 指定的结果集的排序
limit 该子句显示查询出来的数据条数
说明:
所有关键词的使用必须精确地以上面的顺序给出。如,一个having子句必须跟在group by 子句的后面和order by子句之前。
 

---------------------------------------------------------------------------------------------------------------------------------------

#group by 的使用:一般情况下,若查询的需求中有'每'或'各'这个意思就可以用'group by',另外,值得注意的是查询什么
就按什么分组,目的是时查询到的数据没有矛盾。
eg:统计各个部门的人数
select deptcode,count(*)
from tb_user
group by deptcode;
#having条件表达式:用于设置分组或聚合函数的过滤筛选条件的,having子句通常与group by 子句一起使用,用于指定分组后
的筛选条件。
eg:统计各用户发布的新闻条数,要求发布数量大于2。
select inputer,count(*)
from tb_news
group by inputer; --不加筛选 select inputer,count(*)
from tb_news
group by inputer
having count(*)>2; --加上筛选,比较执行结果,确认代码的正确性
#limit子句:返回前几条或者中间某几行数据
eg1:
--查找新闻表最靠前的三条新闻的标题和时间
select title as '标题',time as "发布日期"
from tb_news
order by time asc --这里asc表示升序,在这里可以自动省略,因为是默认的
limit 3; eg2:
--查找新闻表中从第三条记录开始的3条记录的标题和时间
select title as '标题','time' as '发布日期'
from tb_news
order by time
limit 2,3;
#distinct :关键字去除结果中的重复行
select distinct s_id from fruits;
#集合函数:要对表中数据进行统计,都需要使用集合函数。集合函数一般是返回某列的值。
说明:函数的最大特点是经常和 group by 语句配合使用,注意的是集合函数不能和
和非分组的列混合使用。
 
#Union关键字:合并查询结果;
Union:对两个结果集进行并集操作,不包括重复行
Union All:对两个结果集进行并集操作,包括重复行
语法格式:
select column,...
from table A
union [all]
select column,...
from table B
where ... ;
 
#关于索引:当内容较多的时候,可以用索引。
#创建索引的方法
方法一:
在创建表的同时创建索引,语法格式如下
create table 表名(
字段名1 数据类型 [约束条件],
...
[其它约束条件],
[unique|fulltext] index[索引名](字段名[(长度)][asc|desc])
engine=存储引擎 default charset=字符集类型
方法二:
在已经存在的表上创建索引
alter table 表名 add[unique | fulltext] index 索引名(字段名[(长度)][asc|desc]);
#删除索引
drop index xxx on table name;
#视图:一张虚拟的表
目的:为了保护数据库的安全。
#创建视图的格式
create view 视图名[视图字段列表]
as
select 语句;
--在student中为student表创建视图view1。
use choose
create view view1(student_no,student_name,class_no)
as
select student_no,student_name,class_no
from student;
#函数与触发器
触发器是一种特殊的存储过程,触发器没有输入输出参数,一般用于级联更新等操作。

SQL小结1的更多相关文章

  1. MyBatis动态SQL小结

    6:用于实现动态sql的元素及其用法 if+set--完成更新操作 if+where --完成多条件查询 if+完成多条件查询(替代where)或完成更新操作(替代set) choose(when,o ...

  2. oracle sql小结(主要讲横列转换的例子)decode 以及case

    --建表 create table kecheng( id NUMBER, name VARCHAR2(20), course VARCHAR2(20), score NUMBER); --插入数据i ...

  3. SQL小结

    1. 一般而言,除非你确实需要表中的每一列,否则最好别使用*通配符.虽然使用通配符让你自己省事,不用明确列出所需列,但检索不需要的列通常会降低检索和应用程序的性能. 2. DISTINCT关键字作用于 ...

  4. Linq to SQL 小结

    前天开始看这方面的资料,虽然看了网上对比 sql和linq的速度,万条数据可能要慢1/4左右的数度,但是介于的方便,还是学了 首先看看linq的基本语法: FROM XX IN DATASOURCE ...

  5. C#SQL小结

    对于c#获取Sql数据目前我采用的是 System.Data.SqlClient.SqlDataReader类. 主要用到如下API: SqlDataReader.Read():每次获取一行的数据,直 ...

  6. MySQL查询表结构的SQL小结

    mysql查看表结构命令,如下: desc 表名; show columns from 表名; describe 表名; show create table 表名; 示例: use testDB; # ...

  7. oracle sql小结(主要讲横列转换的例子)group by以及wmsys.wm_concat()的使用

    ---计算九月每个电厂的数量select f_dcname,count(f_dcname) as 九月份的数量 from W_EC_PLACESTATION_COLLECT twhere f_coll ...

  8. sql boolean类型

    关于 MySQL 的 boolean 和 tinyint(1) boolean类型MYSQL保存BOOLEAN值时用1代表TRUE,0代表FALSE,boolean在MySQL里的类型为tinyint ...

  9. Oracle sql语句中不支持boolean类型(decode&case)

    [转自] http://blog.csdn.net/t0nsha/article/details/7828538 Oracle sql语句中不支持boolean类型(decode&case) ...

随机推荐

  1. Spring的ApplicationEvent实现

    原理:ApplicationContextAware接口提供了publishEvent方法,实现了Observe(观察者)设计模式的传播机制,实现了对bean的传播.通过ApplicationCont ...

  2. 一、Sql Server 基础培训《进度1-建库建数据表(实际操作)》

    知识点: 1.建数据库示例参考 --创建一个数据库名为‘dbtest’ create database dbtest go --打开数据库 dbtest use dbtest go 2.建表示例参考 ...

  3. Scala 按名称参数调用函数 与 =>的用法

    转自:http://blog.csdn.net/shenxiaoming77/article/details/54835679 通常情况下,函数的参数是传值参数:即参数的值在它被传递给函数之前被确定. ...

  4. MQTT 嵌入式端通讯协议解析(转)

    MQTT,目前物联网的最主要的协议,基本所有收费的云平台都是基于MQTT协议,比如机智云,和所有的开放云平台比如中国移动的oneNet.百度的云平台也都支持MQTT的接入.虽然MQTT很火,但是目前对 ...

  5. PowerBI与Visio

    前言 如何在Power BI中使用Visio, 刚好最近微软推出了适用于Power BI 的 Visio自定义可视化对象预览,分享给大家. 我们先看一下效果:    通过自定义可视化对象,将Visio ...

  6. mysql获取相隔时间段的数据

    思路:为时间段内的数据进行编序号,然后计算好相隔时间,拿到id作为搜索条件 SELECT * FROM ( SELECT (@i:=@i+1) as i, id, data_send_time FRO ...

  7. poj1426_kuagnbin带你飞专题一

    Find The Multiple Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 30659   Accepted: 127 ...

  8. 16 css实现模糊背景

    --------------------- 本文来自 csu_zipple 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/csu_passer/article/det ...

  9. python全栈开发 * 20 继承知识点汇总 * 180530

    20 面向对象的三大特征之一(继承,多态,封装) -----继承 1.继承的定义: 继承是一种创建新类的方式,在python中,新建的类可以继承一个或多个父类;父类又可称为基类或超类,新建的类称为派生 ...

  10. 求最短路的三种方法:dijkstra,spfa,floyd

    dijkstra是一种单源最短路算法.在没有负权值的图上,vi..vj..vk是vi到vk最短路的话,一定要走vi到vj的最短路.所以每次取出到起点距离最小的点,从该点出发更新邻接的点的距离,如果更新 ...