SQL基本查询

查表 :show create table 表名(show tables);

   describe 表名;(desc 表名)//  模糊查询:show table like '%c%';(查询带c的数据表)

基本查询:

  SELECT [DISTINCT] * | 字段名1,字段名2,…FROM  表名  [ WHERE 条件表达式1]
      GROUP BY  字段名【HAVING 条件表达式2】]
        [ORDER BY  字段名 [ASC | DESC] ]
          [ LIMIT [OFFSET] 记录数 ]  
select * | 字段名1,字段名2...from table_name 
SELECT 字段名 【AS】别名 from table_name // 为字段添加别名
 
条件查询:
  where关键字--------对条件语句进行过滤
  IN 关键字------------用于判断某个子弹的值是是否在指定集合中。
  AND关键字---------多条件查询-------满足所有条件则会有结果。
  OR关键字---------满足任意一个条件就会有结果。
  BETWEEN AND 关键字-------查询区间值------判断某个字段值是否在指定的范围内。
  空值查询-----------控制为null,不是啥样没有或者是0;
  DISTINCT 关键字------查询会过滤表中重复的数据
  LIKE 关键字--------模糊查询
    百分号(%)通配符:匹配任意长度的字符串,包括空字符,如:“%c”匹配以字符C开头的。“w%g”表示以w开头g结尾的字符串“可,”%C%“表示出现c的字符串。
    下划线( _ )通配符:只匹配单个 字符,需要匹配多个需要使用多个下划线通配符。
       加入字符串中出现了_或%则用\进行转义。如“\_“和”\%”。
  Having关键字-----设置表达式对结果进行过滤,having关键字可以跟聚合函数,where不能。
select * from table_name where 字段名 [NOT]  IN (元素1,……)
SELECT * | {字段名1,字段名2,…} FROM 表名 WHERE条件表达式 OR 条件表达式2[………] //当and和or关键字一起使用,and的优先级高于OR.
select * from table_name where 字段名 [NOT] BETWEEN 值1  AND 值2;//且结果区间包括值1,不包括值2.
SELECT * | 字段名1,字段名2,… FROM 表名 WHERE 字段名 IS [NOT] NULL;
SELECT DISTINCT 字段名1,字段名2,… FROM 表名;
SELECT * | {字段名1,字段名2,…} FROM 表名 WHERE 字段名 [NOT] LIKE ‘匹配字符串’;
 

 

高级查询:
  聚合函数-------对表中的一组值进行统计,并返回唯一值。如count(),sum()等
   ORDER BY关键字-------对结果进行排序-----Asc升序,desc降序,默认升序。
  分组查询:
    GROUP BY关键字---对某个字段值进行分组。
    group by和聚合函数一起------------统计最大值或啥啥啥之类的,看具体聚合函数。
    group by和Having关键字一起------对分组后的结果进行过滤。
  LIMIT关键字-----限制查询结果的数量-------分页查询中常用到。
  函数----简化用户对数据的操作----字符串函数、数学函数等等
   
select  count(x字段名)  from table_name;  //统计x一共的记录
select * from table_name ORDER BY 字段名 [asc | desc]; //根据字段名进行升序或降序
SELECT 字段名1,字段名2,… FROM table_name GROUP BY 字段名1,字段名2,.....[HAVING条件表达式;];
SELECT 字段名1,字段名2,… FROM table_name LIMIT [OFFSET,] 记录数;
    //OFFSET表示偏移量--默认为0,表示从第1条数据开始返回。
    //记录数 表示返回的查询结果的数量
 
多表查询:
  交叉连接:笛卡尔积--表A的记录数 * 表B的记录数---CROSS JOIN----连接两个表。
  内连接:又称简单连接或自然连接,根据指定的连接条件进行连接查询,只有满足条件的数据才出现在结果集
  外连接:在内连接的基础上,将某个表中不符合条件的记录加入到集合中,一个表只能和一个表外连接。
    左连接----LEFT JOIN----返回包括左表的所有记录和右表的中符合连接条件的记录。
                左外连接:左表完全显示,右表不符合条件的用null显示。关键字 left join  。  
    右连接----RIGHT JOIN---返回包括右表的所有记录和左表中符合连接条件的记录。
                右外连接:右表完全显示,左表不符合条件的用null显示。关键字 right join
              全外连接:连接操作符两侧表中不符合条件的记录加入结果集合中,完全显示两表,没有匹配的记录为空。关键字full join。

交叉连接:select  *  from 表A CROSS JOIN 表B;
内连接:select 查询字段 from 表A [INNER] JOIN 表2 ON 表1.关系子弹 = 表2.关系字段//inner join用于连接两个表,ON指定连接条件
左右连接:select 所查字段 from 表1 LEFT|RIGHT [OUTER] JOIN 表2 ON 表1.关系字段 = 表2.关系字段 where 条件
全外连接:select * from emp e full join depet d on e.depton = d.depton;
子查询:也称嵌套查询。
        单行子查询:只返回一条数据供外层查询语句进行比较操作。
      IN关键字-----外层查询的值与子查询返回值中的某个值相等。
      EXISTS关键字-----后面的参数可以是任意一个子查询,作用是测试,它不产生任何数据,只返回TURE或FALSE。当为TURE时,外部查询才执行。
  
          多行子查询:返回多于一行数据的子查询。
                 ANY(与子查询返回的任何一个值比较)、ALL(与子查询返回的所有值比较)
         ANY关键字--------当子查询返回多个值时,把子查询的多个值当做条件,且满足任意一个条件。
    ALL关键字--------与所有子查询的值比较,且均要满足。     
  
    多列子查询:向外部的SQL语句返回多列
              关联子查询:子查询在执行时需要引用外部父查询的信息
              嵌套子查询:子查询内部嵌套其他子查询,其那套层次最多为255.
select  *  from  table_name where 字段名 IN|<|>  (select 子查询)  ;
 
   
 
 

数据库----SQL基本查询的更多相关文章

  1. Oracle数据库——SQL高级查询

    一.涉及内容 1.掌握SELECT语句的多表连接查询. 2.掌握SELECT语句的子查询. 二.具体操作 (一)根据Oracle数据库scott方案下的emp表和dept表,完成下列操作: 1.查询所 ...

  2. 数据库SQL SELECT查询的工作原理

    一般开发员只会应用SQL的四条经典语句:select,insert,delete,update.但是我从来没有研究过它们的工作原理,这篇我想说一说select在数据库中的工作原理. B/S架构中最经典 ...

  3. 数据库SQL语句查询指定时间段内的数据

    [摘要]有的时候,我们需要查询数据库某段时间之间的数据,比如2016年5月1号到到5月3号之间用户注册数量(特殊节假日期间)等.那么用SQL语句如何实现呢? 首先,数据表中的存时间的字段比如是addt ...

  4. Oracle数据库——SQL基本查询

    一.涉及内容 1.掌握SELECT 语句的基本语法. 2.掌握常用函数的使用. 二.具体操作 (一)使用Scott方案下的emp表和dept表,完成以下操作: 1.查询部门编号是20的员工信息. 2. ...

  5. 如何使用SQL SERVER数据库跨库查询

    SQL Server中内置了数据库跨库查询功能,下面简要介绍一下SQL Server跨库查询.首先打开数据源码:OPENDATASOURCE不使用链接的服务器名,而提供特殊的连接信息,并将其作为四部分 ...

  6. 怎样用SQL语句查询一个数据库中的所有表?

    怎样用SQL语句查询一个数据库中的所有表?  --读取库中的所有表名 select name from sysobjects where xtype='u'--读取指定表的所有列名select nam ...

  7. 怎么用sql语句查询一个数据库有多少张表

    今天在技术群中闲谈时忽然聊到一个问题,那就是当一个数据库中有多张表时怎么快速的获取到表的个数,从而给问询者一个准确的回答. 大家或许会说,这个问题和我们的数据库操作没有太大关系或者不是很挂钩,所以没意 ...

  8. 你用什么方法检查 PHP 脚本的执行效率(通常是脚本执行时间)和数据库 SQL 的效率(通常是数据库 Query 时间), 并定位和分析脚本执行和数据库查询的瓶颈所在?

    php: 一般是在你要检查的代码开头记录一个时间,结尾记录一个时间.取差值, 数据库SQL的效率    sql的explain(mysql),启用slow query log记录慢查询.   通常还要 ...

  9. SQL语句查询数据库的触发器、存储过程、视图以及表的SQL语句

    Sql Server数据库用SQL语句查询方法如下: select name from sysobjects where xtype='TR' --所有触发器 select name from sys ...

随机推荐

  1. [JZOJ4763] 【NOIP2016提高A组模拟9.7】旷野大计算

    题目 题目大意 给你一个数列,有很多个询问,询问一段区间内,某个数乘它的出现次数的最大值,也就是带权众数. 思考历程 第一次看到这道题,立马想到了树套树之类的二位数据结构,发现不行.(就算可以也很难打 ...

  2. SpringBoot_Mybatis MyBatisPlus

    一.SpringBoot中使用Mybatis springBoot中使用mybatis跟以前spring中使用方法一样. 1.mybatis配置: spring: datasource: url: j ...

  3. C++模拟实现Objective-C动态类型(附源码)

    在OC(Objective-C)里面有动态类型分为以下几类: -(BOOL)isKindOfClass:classObj 是否是classObj类或其子类 -(BOOL)isMemberOfClass ...

  4. 高斯消元+期望dp——light1151

    高斯消元弄了半天没弄对.. #include<bits/stdc++.h> using namespace std; #define maxn 205 #define eps 1e-8 d ...

  5. Vue数据双向绑定(面试必备) 极简版

    我又来吹牛逼了,这次我们简单说一下vue的数据双向绑定,我们这次不背题,而是要你理解这个流程,保证读完就懂,逢人能讲,面试必过,如果没做到,请再来看一遍,走起: 介绍双向数据之前,我们先解释几个名词: ...

  6. spss-数据抽取-拆分与合并

    spss-数据抽取-拆分与合并 数据抽取也成为数据拆分,是指保留.抽取原数据表中某些字段.记录的部分信息,形成一个新字段.新纪录.分为:字段拆分和随机抽样两种方法. 一:字段拆分 如何提取" ...

  7. 转:五种I/O模型和select函数简介

    源地址:http://blog.csdn.net/jnu_simba/article/details/9070955 一.五种I/O模型 1.阻塞I/O 我们在前面所说的I/O模型都是阻塞I/O,即调 ...

  8. line-height影响排版

    父级div设置了line-height值,子级div会继承line-height.如果不想子级元素继承,给子级元素设置line-height:normal.

  9. 转载https://www.luogu.org/problemnew/solution/P1665,http://bailian.openjudge.cn/practice/2002/的新解法

    不知道为什么O(n^4)O(n4)的玄学方法能过,正解显然是O(n^2)O(n2)的,枚举对角线,然后算出另外两点判断存不存在. 关键就在怎么通过对角线算出另外两点的坐标. 先贴公式. int mid ...

  10. JavaWEB过滤器和监听器技术

    过滤器介绍 什么是过滤器 生活中的例子: 滤水器,口罩,杯子上滤网,渔网 生活中的过滤器:留下我们想要的,排除,我们不想要的. 高考: 只有分数够高的同学才能进入理想的大学.有一部分同学被拦截在大学之 ...