1、计算列
       select * from emp
          --*表示所有的
          --from emp 表示从emp表查询
 
select empno,ename from emp;
 
select ename,sal*12 as "年薪" from emp
      --as可以省略,记住“年薪“不要写成‘年薪’,也不要写成 年薪,方便移植
 
select ename,sal*12 as "年薪",sal "月薪",job from emp
 
select 5 from emp;
     --OK ,输出一个常量值
     --输出的行数是emp表的行数,每行只有一个字段,值是5
select 5;
     --ok
     --不建议使用,没什么实际意义 
 
注意:
        在Oracle中字段的别名不允许用单引号括起来
        但是SqlServer 2005中却允许
        因此为了兼容性,最好字段别名用双引号括起来,不要用单引号
 
 
2、distinct【不允许重复的】
select distinct deptno from emp;         --distinct deptno 会过滤掉重复的deptno值
 
select distinct comm from emp;         --distinct可以过滤掉重复的null,或者说如果有多个null,会把一个输出
 
 select distinct comm,deptno from emp;          --distinct把comm和deptno的组合进行过滤,查出两两互不相同的记录,
 
select distinct deptno,comm from emp
--含义:把deptno和comm的组合都不重复的输出
 
select deptno,distinct comm from emp --error,deptno的元素多comm中的元素少
 
 select deptno,distinct comm from emp;             --error,逻辑上有冲突
 
学习方式:要多思考
 
3.between【在某个范围之内】
 
--查找工资在1500到3000之间(包括1500到3000)的所有员工的信息
select * from emp where sal between 1500 and 3000;
--等价于
select * from emp where sal>=1500 and sal<=3000;
 
--查找工资小于1500或者大于3000(包括1500到3000)的所有员工的信息
select * from emp where sal<1500 or sal>3000;
 
select * from emp where sal not between 1500 and 3000;
 
4.in【属于若干个孤立值】
 
--把sal=1500 和sal=3000的元素输出
select * from emp where sal in (1500,3000);
--等价于
select * from emp where sal=1500 or sal=3000
 
--把sal不等于1500 和sal不等于3000的元素输出
select * from emp where sal not in (1500,3000);
--等价于
select * from emp where sal!=1500 and sal!=3000
select * from emp where sal<>1500 and sal<>3000
  --数据库中不等于有两种表示:!=,  <>,建议使用第二种
  --多或取反是并且 非并且取反是或
 
 
5、top:【最前面的若干条诗句】可用于分页
select top 2 * from emp;       --筛选出前两行数据
select top 2 from emp;       --error
select top 15 percent * from emp; --如果百分比不是整数则向上取整
 
--把工资在1500到3000 之间(包括1500和300)的员工中工资最高的前4个人的信息输出
select top 4 * from emp where sal between 1500 and 3000 order by sal
--执行过程 from哪个表->where->order排序->top->所有字节
--desc 降序,不写则默认是升序(asc)
 
6、null【没有值,空值】
    ①、零和人null是不一样的,null表示空值,没有值,零表示一个确定的值
    ②、null 不能参与如下的运算:<>  !=  =
    ③、null可以参与如下的运算: is       not is
--输出奖金非空的员工的信息-
select * from emp where comm <> null; --输出为空
select * from emp where comm !=null; --输出为空
select * from emp where comm=null; --输出为空error
  --总结:null不参与<> != = 运算
--null可以参与is not is
select * from emp where comm is null; --输出奖金为空的员工的信息
select * from emp where comm is not null; --输出奖金不为空的员工的信息
 
    ④、任何类型的数据都允许是null
            create table t1(
                name nvarchar(20),
                cnt int,
                riqi datetime
        )
        insert t1 values(null,null,null);
        select * from t1;
 
        ⑤、任何数字与null参与数学运算的结果永远是null
--输出每个员工的姓名 年薪(包含奖金) comm假设是一年的奖金
select empno, ename,sal*12+comm "年薪" from emp;
--此程序证明,任何数字与null参与数学运算的结果永远是null
 
--正确的写法是:
select empno, ename,sal*12+isnull(comm,0) "年薪" from emp;
 --isnull(comm,0)如果comm是null 就返回零,否则返回comm的值
 
7、order by【以某个字段排序】                        
        order by a,b                --a和b都是升序
        order by a,b desc        --a升序,降序
        order by a desc,b        --a降序,b升序
        order by a desc ,b desc    --a降序,b降序
        
        文字描述
                如果不指定排序的标准,则默认是升序,升序用asc表示,默认可以不写
                为一个字段指定的排序标准并不会对另外一个字段产生影响
 
        强烈建议为每一个字段都指定排序的标准
 
例子:
--asc是升序的意思,默认可以不写,desc是降序
select * from emp order by sal --默认是按照升序排序
select * from emp order by deptno,sal; -- 先按照deptno升序排序,如果deptno相同,再按照sal升序排序
select * from emp order by deptno desc,sal ;
  --先按照deptno降序排序,如果deptno相同,再按照sal升序排序,
  --记住sal是升序,不是降序
  --order by a desc,b,c,d desc 只对a产生影响, 不会对后面的b、c、d产生影响
 
 select * from emp order by deptno,sal desc;
 --问题:desc是否会对deptno产生影响?
 --答案:不会、
 --先按deptno升序,如果deptno相同,再按sal降序
 
 
8、模糊查询
格式:
  select 字段的集合 from 表名 where 某个字段的名字 like匹配的内容

  匹配的条件通常含有通配符

%

表示任意0个或者多个字符
select * from emp where ename like '%A%';  --ename 只要含有字符A就输出
select * from emp where ename like 'A%'; --ename 只要首字母是A的就输出

select * from emp where ename like '%A'; --ename 只要未字母是A的就输出
_[这是下划线 不是减号]
表示 单个字符
select * from emp where ename like '_A';--ename只要第二个字母是A的就输出
[a-f]
a到f中的任意单个字符,只能是a b c d e f中的任意一个
select * from emp where ename like '_[A-F]%';

--把ename中第二个字母是A或B或C或D或E或F的数据输出
[a,f]
a或f
[^a-c]

不是a,也不是b,也不是c的任意单个字符

select * from emp where ename like '_[^A-F]%';
--把ename中第二个字母不是A也不是B也不是C也不是D也不是E也不是F的数据输出

注意:
   匹配的条件必须用单引号括起来   不能省略  也不能改用双引号

   通配符
通配符作为不同字符使用的情况

  select * from 表明 where name like '%\%%'  escape '\'   --把name中包含有%的输出
  select * from 表明 where name like '%m%%'  escape 'm' // escape 后面的内容表明在其之后的元素当做转义字符

sql 查询基本语法的更多相关文章

  1. SQL Server 数据库子查询基本语法

    一.SQL子查询语句 1.单行子查询        select ename,deptno,sal        from emp        where deptno=(select deptno ...

  2. SQL Server参数化SQL语句中的like和in查询的语法(C#)

    sql语句进行 like和in 参数化,按照正常的方式是无法实现的 我们一般的思维是: Like参数化查询:string sqlstmt = "select * from users whe ...

  3. MySQL 基本语法(1.表字段操作,2表记录管理 3.运算符管理4.SQL查询 5.约束6.索引

    .表字段的操作 .语法:alter table 表名 执行动作; .添加字段(add) .添加到末尾 alter table 表名 add 字段名 数据类型; .添加到第一列 alter table ...

  4. SQL DATEDIFF语法及时间函数 Sql 查询当天、本周、本月记录

    SQL DATEDIFF语法及时间函数 Sql 查询当天.本周.本月记录 转:http://blog.csdn.net/Json1204/article/details/7863801?locatio ...

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

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

  6. SQL查询语法30例

    学好SQL查询:无他,概手熟耳. 1. 基础表: 学生表: 老师表: 课程表: 成绩表: 2. 题目: 1.查询名字中含有"华"字的学生信息 select * from 学生 wh ...

  7. SQL中部分语法整理

    1.SELECT DISTINCT 语句 关键词DISTINCT用于返回唯一不同的值. 语法: SELECT DISTINCT 列名称 FROM 表名称 2.SELECT INTO语句 SELECT ...

  8. Oracle常用SQL查询(2)

    三.查看数据库的SQL 1 .查看表空间的名称及大小 select  t.tablespace_name,  round ( sum (bytes / ( 1024 * 1024 )), 0 ) ts ...

  9. SQL server存储过程语法及实例(转)

    存储过程如同一门程序设计语言,同样包含了数据类型.流程控制.输入和输出和它自己的函数库. --------------------基本语法-------------------- 一.创建存储过程cr ...

随机推荐

  1. AEAI CRM客户关系管理升级说明

    本次发版的AEAI CRM_v1.5.1版本为AEAI CRM_v1.5.0版本的升级版本,该产品现已开源并上传至开源社区http://www.oschina.net/p/aeaicrm. 1 升级说 ...

  2. Json的序列化和反序列化

    1.利用js进行序列化成字符串和反序列化 var personObj = {name:"Tom",age:16}; // 利用JS序列化成字符串 var personStr = J ...

  3. 设置窗体透明C#代码

    上个示例是C#调用windows api 在原来代码上加入窗体透明,控件不透明代码: using System; using System.Runtime.InteropServices; using ...

  4. 【C#】1.1 第1章学习要点

    分类:C#.VS2015 创建日期:2016-06-14 教材:十二五国家级规划教材<C#程序设计及应用教程>(第3版) 一.配套源程序(VS2015版)的运行截图 VS2015版的配套源 ...

  5. 【JS复习笔记】00 序

    作为一个前端苦手,说是复习,你就当我是重学好了. 好吧,我当然不可能抱着一个砖头去复习,所以捡了本薄的来读——<JavaScript语言精粹>. 当初带我的人说这本书挺好,就看这本书好了. ...

  6. 运行QQ出现initialization failure 0x0000000c错误和浏览器上不了网

    出现QQ出现initialization failure 0x0000000c错误和浏览器上不了网的问题,原因是关机的时候没有正常关闭导致的. 解决方法: 1.我们在开始菜单栏中的附件中找到“命令提示 ...

  7. ugui 获取Text的高度,动态改变高度

    项目中需要根据聊天内容的多少.显示外边框的高度.因为Text的内容是不固定的.但宽度是固定的.高度根据文字多少自增 可以通过Text的属性preferredHeight 获取文本框的高度

  8. EffectiveJava——用函数对象表示策略

    有些语言支持函数指针.代理.lambda表达式,或者支持类似的机制,允许程序把“调用特殊函数的能力”储存起来并传递这种能力.这种机制通常用于允许函数的调用者通过传入第二个函数,来指定自己的行为.比较器 ...

  9. jQuery pgwslideshow 空间相册

    一个响应式相册插件,你可以自定义幻灯片最大高度,滑动效果,是否显示控制按钮,自动轮播或间隔时间. pgwslideshow相册插件有以下特点    支持响应式    支持桌面和移动设备    代码简单 ...

  10. js中创建对象的几种方式

    创建对象指创建一个object并给这个对象添加属性和方法,有以下几个方式: 最基本的: var Person={}; Person.name='tom'; Person.age='20'; Perso ...