数据库原理-SQL查询语句
参考书籍《Oracle 数据库开发与应用》
SQL查询语句,针对数据库中的表提供了各种查询功能。这里分为五个部分,说明在SQL中如何对数据进行查询。
简单查询
SELCET语句是最简单的SQL语句,格式为
----------------------------------------
SELECT {*,列名[别名],···}
FROM 表名;
-----------------------------------------
在SELECT语句中,具有以下性质:1.包含算术表达式 2.给字段起别名 3.空值在结果中无限大 4.用DISTINCT关键字去掉重复值
*还可以带有限制条件的查询,这也是最常用也非常重要的。
1.WHERE 限制
在WHERE子句中一般是一个字段/公式与一个值的比较,可以使用关系运算符(进行数据过滤)、逻辑运算符(多个条件限制查询)
2.BETWEEN···AND定位范围
3.IN代替OR运算符
4.LIKE模糊查询
5.ORDER BY排序
可以对多个字段排序,支持通过别名排序, 注意ORDER BY子句只能出现在整个SELECT语句最后。
连接查询
分为内连接、外连接和其他连接。
*内连接,基本格式为-------------------------------------------
SELECT 列名
FROM 表名1
JOIN 表名2 ON 相等条件
···
WHERE 其他条件;
--------------------------------------------
*外连接,使用等号作为连接操作符,不仅可以看到等值的记录,还能看到不满足等值连接条件的记录。如果一方表的连接列值在另一方表内找不到,则将找不到的内容用NULL值显示。有左外连接(LEFT OUTER JOIN )、右外连接(RIGHT OUTER JOIN)、完全外连接(FULL OUTER JOIN)。
聚合函数
聚合函数也称多行函数,常见的聚合函数:
1.COUNT
2.AVG
3.SUM
4.MAX & MIN
这里有一个容易出错的地方:如果是直接查询最值没有问题,但要将最值的相应字段显示出来就不能直接SELECT。
解决方法:1-排序后取需要的某几条记录(使用RUWNUM子句)
2-使用子查询
在SELECT中嵌套SELECT最值查询。
5.GROUP BY
即按照一个或多个字段进行分组,规则:出现在SELECT中的字段,如果没有出现在聚合函数,就必须出现在GROUP BY子句,且子句紧跟在WHERE 子句后面
6.HAVING
注意,HAVING 后面的列名不能用别名。
到这里,可以总结出一个基本完整的SQL语句结构:
----------------------------------------------------
SELECT
FROM
[WHERE ]
[GROUP BY]
[HAVING ]
[ORDER BY ];
-----------------------------------------------------
子查询
也就是嵌套查询。
*使用位置:
1-在WHERE/HAVING中使用
2-在FROM中使用
3-在SELECT中使用 (关联子查询可以在这三个位置中巧妙使用)
*用WITH/ROWNUM
1-WITH可以暂存查询结果重复使用
2-ROWNUM表明查询的行号,从1开始。*注意:要直接访问大于1的值,可以使用子查询,例如查询某个 范围使用BETWEEN AND;还可以和ORDER BY联系使用。
*相关运算符
1-EXISTS关键字
2-多行比较运算符
3- 结果集的合并和保存(UNION)
单行数据处理函数
1-字符串处理函数
2-数值处理函数
3-日期处理函数
4-类型转换函数
5-其他函数
NVL(X,Y)用于将空值转换为一个替换值。
DECODE函数可以进行选择判断。
数据库原理-SQL查询语句的更多相关文章
- WordPress 常用数据库SQL查询语句大全
在使用WordPress的过程中,我们少不了要对数据库进行修改操作,比如,更换域名.修改附件目录.批量修改文章内容等等.这个时候,使用SQL查询语句可以大大简化我们的工作量. 关于如何操作SQL查询语 ...
- [数据库] SQL查询语句表行列转换及一行数据转换成两列
原文来自:http://blog.csdn.net/Eastmount/article/details/50559008 本文主要讲述了SQL查询语句表之间的行列转换,同时也包括如何将一行数据转换成两 ...
- MySQL数据库详解(一)执行SQL查询语句时,其底层到底经历了什么?
一条SQL查询语句是如何执行的? 前言 大家好,我是WZY,今天我们学习下MySQL的基础框架,看一件事千万不要直接陷入细节里,你应该先鸟瞰其全貌,这样能够帮助你从高维度理解问题.同样,对于MyS ...
- 15个初学者必看的基础SQL查询语句
本文由码农网 – 小峰原创翻译,转载请看清文末的转载要求,欢迎参与我们的付费投稿计划! 本文将分享15个初学者必看的基础SQL查询语句,都很基础,但是你不一定都会,所以好好看看吧. 1.创建表和数据插 ...
- (转)经典SQL查询语句大全
(转)经典SQL查询语句大全 一.基础1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql s ...
- 经典SQL查询语句大全
一.基础1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备份数 ...
- SQL查询语句分类
SQL查询语句有多种,下面总结下.首先先建三张表用于后面的实验 -- 学生表,记录学生信息 CREATE TABLE student( sno ), sname ), ssex ENUM('男','女 ...
- C# EF使用SqlQuery直接操作SQL查询语句或者执行过程
Entity Framework是微软出品的高级ORM框架,大多数.NET开发者对这个ORM框架应该不会陌生.本文主要罗列在.NET(ASP.NET/WINFORM)应用程序开发中使用Entity F ...
- 将Sql查询语句获取的数据插入到List列表里面
Sql查询语句获取的数据是分格式的,我们还用SqlDataReader来做,然后用IDataReader来接收读取,以下是代码: //我想查询一个用户表的信息,该用户有姓名,密码,信息三列 //1.定 ...
- sql查询语句优化
http://www.cnblogs.com/dubing/archive/2011/12/09/2278090.html 最近公司来一个非常虎的dba 10几年的经验 这里就称之为蔡老师吧 在征得 ...
随机推荐
- 如何在路由绑定中使用 IParsable
IParsable 是 .Net 7 中新增的接口,它可以将字符串转换为对应的实体.在 Controller 的 Route 绑定中可以使用 IParsable 来绑定复杂的实体. 实验背景 假设有一 ...
- 侦察工具——Httrack
前言 web渗透学习笔记,实验环境为Metasploitable靶机上的DVWA.此随笔介绍Web渗透侦察工具Httrack Httrack 简介 Httrack能够克隆拷贝目标网站上的所有可访问.可 ...
- [机器学习] Yellowbrick使用笔记3-特征分析可视化
特征分析可视化工具设计用于在数据空间中可视化实例,以便检测可能影响下游拟合的特征或目标.因为ML操作高维数据集(通常至少35个),可视化工具将重点放在聚合.优化和其他技术上,以提供对数据的概述.这是Y ...
- [python]《Python编程快速上手:让繁琐工作自动化》学习笔记6
1. 发送电子邮件和短信笔记(第16章)(代码下载) 1.1 发送电子邮件 简单邮件传输协议(SMTP)是用于发送电子邮件的协议.SMTP 规定电子邮件应该如何格式化.加密.在邮件服务器之间传递,以及 ...
- lock 和 Monitor (转载)
Lock和Monitor都是对被操作对象同步控制的方法 Lock 是 Monitor的简化版本,IL callvirt ...Monitor.Enter(object)...leave.s.... c ...
- JSP第八次作业
数据库test 中建个表 stu(stuid 主键 自动增长 ,用户名,密码,年龄) 1.设计一个注册页面,实现用户注册功能2.设计一个登陆页面,实现用户名密码登陆3.两个页面可以互相超链接 1 pa ...
- 无法将“obj\Debug\net5.0\xxx.dll”复制到“bin\Debug\net5.0\xxx.dll”。超出了重试计数 10。失败。
解决办法 VS选中项目,右键清理解决方案,再次右键重新生成方案即可. 以上就是无法将"obj\Debug\net5.0\xxx.dll"复制到"bin\Debug\net ...
- 为Jekyll静态网站添加PlantUML插件
前言 突然想起来要好好整理一下自己的博客空间,已经荒废很多年,如果再不捡起来,等到自己知识老化的时候再去写东西就没人看了. 使用Github Pages + Jekyll把博客发布为静态网站,给人感觉 ...
- 学习Java Day18
一.面向对象(面向过程) 1. 面向对象 找对象(封装了过程)来干. 例如:洗衣服(洗衣机就是对象). 2. 面向对象思想特点 是一种更符合我们思想习惯的思想. 可以将复杂的事情简单化. 将我们从执行 ...
- 记一次使用tika解析文件文本导致的内存溢出问题
背景 笔者曾供职于某信息安全公司,接到过一个需求,提取文档中的文本以供后续分析.tika是apache开源的解析文档内容的组件,应用十分广泛.tika几乎支持你能想到的所有文档格式,docx , pp ...