数据库原理-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几年的经验 这里就称之为蔡老师吧 在征得 ...
随机推荐
- Html飞机大战(十八): 模块化+项目开源
好家伙,好久好久没有更新这个系列了 为了使文档更方便阅读,使代码更容易维护,来把这个飞机大战模块化 项目已开源: https://gitee.com/tang-and-han-dynasties/ ...
- 51NOD5213A 【提高组/高分-省选预科 第一场【M】】序列
小 Y 酷爱的接龙游戏正是这样.玩腻了成语接龙之后,小 Y 决定尝试无平方因子二元合数接龙,规则如下: 现有 \(n\) 个不超过 \(K\) 的合数,每个合数 \(a\) 均可表示为 \(a=pq( ...
- pytest框架的简介
概念:是一款基于python语言的单元测试框架 用途:用于发现测试用例.执行测试用例.判断测试结果.生成测试报告的一款框架 测试用例的规则: 测试文件必须与test开头,或_test结尾 类文件必须T ...
- C Primer Plus 5.11 編程練習
/*C Primer Plus (5.10) 9*/ 1 #include<stdio.h> 2 #define G 103 3 int main() 4 { 5 char ch=96; ...
- Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.1.0
maven package 异常,今天打包springboot项目时碰到的问题. Failed to execute goal org.apache.maven.plugins:maven-resou ...
- 浅谈Python中的if,可能有你不知道的
Python中的if,没那么简单,虽然也不难 https://docs.python.org/zh-cn/3.9/reference/compound_stmts.html#if python语言参考 ...
- JAVA虚拟机22-原子性、可见性与有序性、先行发生原则
1 简介 Java内存模型是围绕着在并发过程中如何处理原子性.可见性和有序性这三个特征来建立的,我们逐个来看一下哪些操作实现了这三个特性 2 原子性 2.1 操作指令 由Java内存模型来直接保证 ...
- Axios、Vue组件-生命周期、计算属性、Slot插槽、自定义事件、v-router、钩子函数
Axios:网络通信 <script> var vm =new vue({ el:"#app", data(){ return{ info:{ //返回的数据必须和js ...
- NuGet私有服务器ProGet Docker搭建和公司中实战用法
一.什么时候需要用到NuGet私有服务器 很多公司中架构师会搭建一个统一的项目基础架构模板,然后全部新项目都会拿这个基础架构来开发新的项目,那架构中就会有很多的中间件,比喻公司内部的封装好的Redis ...
- SVN服务器的安装与使用
一.下载服务端和客户端安装包 百度网盘: 链接:https://pan.baidu.com/s/1QkNbLR9ZkcYPiBp6d_drlQ 提取码:tmi5 也可以在官网自行下载. 二.服务端安装 ...