DML数据操作语言之查询(一)
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数据操作语言之查询(一)的更多相关文章
- DML数据操作语言之查询(二)
当我们查询出了N条记录之后 ,我们知道一共是几条记录,或者这些记录某一字段(列值)的最大值,最小值,平均值等,就可以使用聚合函数. 1.聚合函数 聚合函数会将null 排除在外.但是count(*)例 ...
- 6.1课堂笔记—DML(数据操作语言),DQL查询语句
一.DML(数据操作语言) InnoDB MyISAM 支持事务 不支持事务 不支持全文索引 支持全文索引 支持外键约束 不支持 命令查看默认存储引擎 show variables like '%st ...
- DML数据操作语言
DML数据操作语言 用来对数据库中表的数据记录进行更新.(增删改) 插入insert -- insert into 表(列名1,列名2,列名3...) values (值1,值2,值3...):向表中 ...
- DML数据操作语言之增加,删除,更新
1.数据的增加 数据的增加要用到insert语句 ,基本格式是: insert into <表名> (列名1,列名2,列名3,......) values (值1,值2,值3,..... ...
- DML数据操作语言之复杂查询
1.视图(View) 我们知道,在关系型数据库中,用来保存实际数据记录的是数据表.和表同等概念也是用来保存东西是:视图. 但是数据表是用来保存实际数据记录的,而视图是用来保存常用select语句的. ...
- DML数据操作语言之谓词,case表达式
谓词:就是返回值是真值的函数. 前面接触到的“>” “<” “=”等称为比较运算符,它们的正式名称就是比较谓词.因为它们比较之后返回的结果是真值. 由于谓词 返回的结果是一个真值 ,即tr ...
- DML数据操作语言之常用函数
所谓函数,就是输入某一值,得到相应的输出结果的功能.相当于一个加工厂,给了原料,最终产出成品. 其中原料 就是参数(parameter). 产品 就是返回值. 函数大致可以分为以下五个种类: 算术函数 ...
- MySQL SQL DML (数据操作语言)
包括 SELECT, UPDATE, DELETE, INSERT SELECT 从数据库表中获取数据 用法 SELECT name FROM students; SELECT name,age FR ...
- DML数据操作语言练习
--创建表T_HQ_BM2 --create table t_hq_bm2 as select * from t_hq_bm; commit; --添加行内容 --insert into t_hq_b ...
随机推荐
- 【BZOJ1855】股票交易(动态规划,单调队列)
[BZOJ1855]股票交易(动态规划,单调队列) 题面 BZOJ 题解 很显然,状态之和天数以及当天剩余的股票数有关 设\(f[i][j]\)表示第\(i\)天进行了交易,剩余股票数为\(j\)的最 ...
- 【LightOJ1282】Leading and Trailing(数论)
[LightOJ1282]Leading and Trailing(数论) 题面 Vjudge 给定两个数n,k 求n^k的前三位和最后三位 题解 这题..真的就是搞笑的 第二问,直接输出快速幂\(m ...
- ZJOI2007仓库建设
斜率优化 # include <stdio.h> # include <stdlib.h> # include <iostream> # include <s ...
- [BZOJ1041] [HAOI2008] 圆上的整点 (数学)
Description 求一个给定的圆(x^2+y^2=r^2),在圆周上有多少个点的坐标是整数. Input 只有一个正整数n,n<=2000 000 000 Output 整点个数 Samp ...
- 关于Flex的DataGridColumn 的editorDataField属性
本人Flex菜鸟,纯纯的小白 最近在项目中提了一个需求,其实这个需求就是在原有的列表中接一列数据,只不过这一列数据是下拉列表选择的 最关键的是貌似以前的某一位大神已经添加过,我的工作就是调通,可是就是 ...
- [转]ZooKeeper的学习与应用
[转]ZooKeeper的学习与应用 http://blog.csdn.net/rengq126/article/details/7393227 1. ZooKeeper的学习与应用 1.1. 概述 ...
- JavaScript编码规范(1)
参考的是百度公司的JS规范,分为两部分.这是第一部分 [建议] JavaScript 文件使用无 BOM 的 UTF-8 编码. 空格 [强制] 二元运算符两侧必须有一个空格,一元运算符与操作对象之间 ...
- 在Vue.js2.0中组件模板子元素数量问题
在Vue中当利用组件进行开发时候,组件所使用的模板只可以应用于一个根实例,当你需要添加多个子元素的时候,可以用一个div将它们包裹起来,代码如下: <template id="task ...
- 温故而知新--hashtable
哈希在实际使用中主要是当作私有内存,对数据进行插入和查找,哈希数据元素越多,操作的时候消耗的性能就越到,最明显的是当数据元素达到哈希的容量大小时,插入数据冲突概率会变大,并慢慢的退化为数组. 本例子中 ...
- python初识(一)
python语言的发展 python语言诞生于1990年,由Guido van Rossum设计并领导开发. 1989年12月,Guido为打发圣诞节时间而开发的项目. python名字的由来,由于当 ...