1.select语句基础

基本语句格式:  select <列名>,.... from <表名>;

select子句中列举出希望从表中查询出的列的名称,from子句则指定了选取出数据的表的名称。

查询结果表中列的顺序和select子句中列名的顺序相同。

查询出表中所有的列,可以使用星号(*)来代表所有的列。 select * from <表名>; 。这样就无法指定查询结果表中列的顺序。

为查询结果表的列名设置别名,使用as: select <列名> as <别名> ,...... from <表名>;

别名是英文单词时,无需使用引号。别名是中文时,需要使用双引号" ",注意不是单引号。

为查询结果表增加常数列: select <常数> as <别名> , ...... from <表名>;

从查询结果表中去除某列的重复行,使用 distinct: select distinct <列名> from <表名>;

当查询结果表是多列,根据某两列的值或者多列的值都相同时,认为是重复行, select distinct <列名1>,<列名2>,...... from <表名>; 列名1,列名2....都相同时,去掉重复列。

注意:distinct关键字只能在第一个列名之前出现。

上面所查询出来的查询结果表 包含了原始表的所有行记录(如果不去重),但是实际上要根据某些条件来选出符合条件的行记录,

根据where子句来选择记录:

select  <列名>,<列名>,.......  from <表名>  where <条件表达式>;

首先通过where子句查询出符合指定条件的行记录,然后在在这些行记录中,根据select子句中选取指定的列来组成查询结果表。

一条SQL语句中select子句,from子句,where子句 三者的顺序是固定的 ,不能随意更改。

单行注释:  -- 注释内容

多行注释:  /* 注释内容 */

2.算术运算符和比较运算符

算术运算符 :+   —   *   /       可以使用括号来提升运算优先级。        算术运算符可以出现在 select子句  和 where子句中

如:

select  (<列名> + 5 ) * 2  ,....... from  <表名>  where  <条件表达式> ;

所有包含NULL的计算,结果肯定是NULL.

比较运算符:   = (相等)   <> (不相等) >= (大于等于)   <=(小于等于)  > (大于)  < (小于)      比较运算符出现在 where子句中

其中不相等符号<>  这是标准SQL的写法 ,但是不同的数据库管理系统(DBMS)可能会提供更加常用的  !=

比较运算符可以对字符(char , vchar)数字(int ,lang),日期(date)等几乎所有的数据类型的列的值进行比较。如:

select  <列名>,.......  from  <表名>  where  
<列名> = 2500 and
<列名> >= '2019-09-27' and
<列名> < '' and
<列名> is not null;

对于字符型的值,使用比较运算符,是按照字典顺序进行比较的。 如 ‘110’ 小于 ‘22’ , 'abd'  大于 ‘abc’

对于日期型的值,使用比较运算符,该日期之前的日期 小于该日期。该日期之后的日期 大于改日期。

选取某列值为null的记录时,需要在条件表达式中使用  is null运算符。希望选取某列值不是null的记录时,需要在表达式中使用 is  not  null运算符。

3.逻辑运算符

通过逻辑运算符 可以将多个查询条件进行组合。      逻辑运算符出现在where子句中。

常用的逻辑运算符有三个:

not  : 相当于 “非”    如:

select  ......  from  ......   where   not   t.id <= 100 ;          -- 将查出 t.id > 100  的记录

and :相当于 “与”

select  ......    from  ......    where   t.id > 100  and  t.age = 25    --将查出t.id>100 并且 t.age = 25 的记录

or  : 相当于 “或”

select  .....   from .....  where  t.id > 100 or  t.age  =  25  --- 将查出 至少满足其中之一的查询条件的记录

通过括号进行强化:

and运算符的 优先级 高于 or运算符。 类似于四则混合运算  *  /的优先级高于  + -

可以利用()来 来对or连接的两个条件式先进行组合筛选出记录 ,然后再于 and运算符 进行联合来筛选记录。

select .......    from  .....    where  (t.age = 25 or t.birthdat > '2000-09-15') and
t.id  > 100 ;

如果不加(),如下: 将进行and运算符的连接 然后再进行 or运算符的连接。

select .......    from  .....    where  t.age = 25 or t.birthdat > '2000-09-15'  and
t.id > 100 ;

含有null 时的真值:

不确定。

DML数据操作语言之查询(一)的更多相关文章

  1. DML数据操作语言之查询(二)

    当我们查询出了N条记录之后 ,我们知道一共是几条记录,或者这些记录某一字段(列值)的最大值,最小值,平均值等,就可以使用聚合函数. 1.聚合函数 聚合函数会将null 排除在外.但是count(*)例 ...

  2. 6.1课堂笔记—DML(数据操作语言),DQL查询语句

    一.DML(数据操作语言) InnoDB MyISAM 支持事务 不支持事务 不支持全文索引 支持全文索引 支持外键约束 不支持 命令查看默认存储引擎 show variables like '%st ...

  3. DML数据操作语言

    DML数据操作语言 用来对数据库中表的数据记录进行更新.(增删改) 插入insert -- insert into 表(列名1,列名2,列名3...) values (值1,值2,值3...):向表中 ...

  4. DML数据操作语言之增加,删除,更新

    1.数据的增加 数据的增加要用到insert语句  ,基本格式是: insert into <表名> (列名1,列名2,列名3,......) values (值1,值2,值3,..... ...

  5. DML数据操作语言之复杂查询

    1.视图(View) 我们知道,在关系型数据库中,用来保存实际数据记录的是数据表.和表同等概念也是用来保存东西是:视图. 但是数据表是用来保存实际数据记录的,而视图是用来保存常用select语句的. ...

  6. DML数据操作语言之谓词,case表达式

    谓词:就是返回值是真值的函数. 前面接触到的“>” “<” “=”等称为比较运算符,它们的正式名称就是比较谓词.因为它们比较之后返回的结果是真值. 由于谓词 返回的结果是一个真值 ,即tr ...

  7. DML数据操作语言之常用函数

    所谓函数,就是输入某一值,得到相应的输出结果的功能.相当于一个加工厂,给了原料,最终产出成品. 其中原料 就是参数(parameter). 产品 就是返回值. 函数大致可以分为以下五个种类: 算术函数 ...

  8. MySQL SQL DML (数据操作语言)

    包括 SELECT, UPDATE, DELETE, INSERT SELECT 从数据库表中获取数据 用法 SELECT name FROM students; SELECT name,age FR ...

  9. DML数据操作语言练习

    --创建表T_HQ_BM2 --create table t_hq_bm2 as select * from t_hq_bm; commit; --添加行内容 --insert into t_hq_b ...

随机推荐

  1. 在VCS仿真器中使用FSDB

    FSDB(Fast Signal Database)是Verdi支持的文件格式,用于保存仿真产生的信号波形.据Verdi文档说明,FSDB比标准的VCD格式节省磁盘空间,处理速度更快.要用VCS仿真器 ...

  2. HDU4812

    树分治 求逆元请递推,不然会TLE 开桶记录即可 注意常数 # pragma comment(linker,"/STACK:102400000,102400000") # incl ...

  3. BZOJ2693jzptab

    简单般Bzoj2154: Crash的数字表格 Sol 增加了数据组数T<=10000 推到 \(ans=\sum_{d=1}^{N}d*\sum_{i=1}^{\lfloor\frac{N}{ ...

  4. [BZOJ1036] [ZJOI2008] 树的统计Count (LCT)

    Description 一棵树上有n个节点,编号分别为1到n,每个节点都有一个权值w.我们将以下面的形式来要求你对这棵树完成一些操作: I. CHANGE u t : 把结点u的权值改为t II. Q ...

  5. Appserv(Apache) 设置网页不显示目录(索引)

    首先在appserv安装目录下找到httpd.conf文件 ./AppServ/Apache24/conf/httpd.conf 打开文件,找到 Options Indexes FollowSymLi ...

  6. asp.net core 四 IOC&DI Autofac

    其实关于IOC,DI已经有了很多的文章,但是自己在使用中还是有很多困惑,而且相信自己使用下,印象还是会比较深刻的 关于这段时间一直在学习.net core,但是这篇文章是比较重要的,也是我自己觉得学习 ...

  7. vue.js 配置移动端的url Scheme和iOS端配置url Scheme

    假如urlScheme:baibai:// 一.vue.js端的配置: 1.通过html标签跳转: <p href="baibai://"></p> 2.通 ...

  8. 用js制作日期 2017-03-23

    日期表: <body> <select id="year" ></select>年 <select id="month" ...

  9. The summary of Interview

    面试汇总 运维工程师日常工作内容 自我介绍对公司的了解 系统管理员的职责 进行系统资源管理.设备管理.系统性能管理.安全管理和系统性能监测: 管理的对象 服务器.用户.服务器的进程及系统的各种资源等. ...

  10. mysql存储过程(查询数据库内表 游标循环 if判断 插入别的表内)

    BEGIN declare f_age int;DECLARE incode1 VARCHAR(100);DECLARE incode2 VARCHAR(100);DECLARE incode3 VA ...