文档章节

oracle数笔一

m243043962
 m243043962
发布于 2017/08/12 15:51
字数 993
阅读 2
收藏 0
点赞 0
评论 0

oracle 单行函数 
lower :
update:
concat :连接两个字符串
ltrim
rtrim
trim
abs 
ceil
floor
sysdate
to_char
to_date


聚合函数 
count :统计有效数据的数量 
max
min
avg :只能用在数字列上
sum 


分组 group by :就是将相同内容的分为一组 

当查询中出现了group by 分组的时候,那么select显示的列,要么是group by 分组列 ,要么是聚合函数列。

having 对分组之后的数据进行二次过滤 。

decode函数的用法 。
1.可以用来分组统计

select decode(1+1 , 2 ,'ok' ,'error') from dual; 

select t1.* , decode(job,'OPERATION','operation','vp_ceo') from t1 

select decode(job,'OPERATION','operation','vp_ceo'),count(*) from t1 
group by decode(job,'OPERATION','operation','vp_ceo')


2.可以用来动态排序

order by 列名 asc | desc 


select dept.* 
 from dept order by decode(d_name,'销售部',1,'开发部',2,'业务部',3,4)


3.可以用来行转列 。

select   s_years ,
sum(decode(s_months,'1季度',s_money))  一季度,
sum(decode(s_months,'2季度',s_money)) 二季度,
sum(decode(s_months,'3季度',s_money)) 三季度,
sum(decode(s_months,'4季度',s_money)) 四季度
  from sales 
group by s_years order by s_years; 


多表查询 。因为在某些情况下,一张表的数据不能完全满足我们的需求 。

查询员工信息,并且显示员工所在的部门 。

多表连接查询,需要条件。
1.从多表中查询数据,from关键字后面跟多个表名,用逗号隔开。
2.需要多个表中有相同意义的字段。需要指明


select * from emp ,dept where emp.deptno = dept.d_id ; 
emp.deptno = dept.d_id ;
表示的emp表中deptno这个列的值,同时存在于 dept表的d_id列中
才查询出来,这种两个表中都存在的才查询出来的连接,称之为 内连接。

外连接 :首先需要以一张表为基表 ,基表的数据会全部显示。同时显示和另外一张表中匹配的数据。 如果没有匹配的数据,用空来填充。

左外连接 left outer join  ....  on  关联关系
:左外连接就是以左边的表为基表 , 

select * from emp left join dept on emp.deptno = dept.d_id ; 

右外连接 right outer join 


oracle里面本身的外连接写法 ,使用(+) 来表示的。
(+)在哪个表后面,哪个表就是匹配表,另外一个表叫 基表。

select * from emp ,dept where emp.deptno = dept.d_id;

内连接 15 条匹配的。 
以emp 表为基表 15 条匹配的,2 条不匹配的。
以deptno 表为基表  15 条匹配的,3条匹配的。


全外连接 full join ,全外连接,不能使用(+)来表示 。
同时也没有基表 。

显示两表匹配的数据,同时显示两表不匹配的数据 。


select * from emp full join dept where emp.deptno = dept.d_id ; 
显示20 条数据  15 + 2 +3  ;


约束:其实就是一种限制性的行为。

表约束 :其实就是对表的一种限制性的行为,如果不满足表的约束,那么对表执行增 删  ,改  就不能成功。

1.默认约束 default  
2.非空约束 not null
3.唯一约束 unique :不能重复,可以为空 
4.主键约束 primary key:不能重复,不能为空
5.检查约束 check : 限制在某个区间范围内 
6.外键约束 foreign key 
首先需要在两个表中,并且一个表中可以存在多个外键。


作用:当给某一列设置了外键之后,相当于限制了这一列值的取值范围,只能从主表的主键中取值 。  最终可以到达保障数据的完整性。

d :主表
e :外表(子表)

当表创建之后,是否可以继续添加约束 ?

--只适用于  唯一约束  主键约束   check约束  外键约束 
alter table 表名 add constraint 约束名 约束类型 (列名) ;


--非空约束  默认约束
alter table 表名 modify(列名 not null |default '')


emp  eid 添加主键 。
alter table emp add constraint pk_eid primary key (eid) ;
alter table emp add constraint uq_eid unique (eid) ;
alter table emp add constraint ck_age check (age between 10 and 20) ;

alter table emp add constraint fk_dno foreign key (dno)
references 主表(主键) ;

© 著作权归作者所有

共有 人打赏支持
m243043962
粉丝 0
博文 69
码字总数 34357
作品 0
黄冈
程序员
【腾讯优测干货分享】从压测工具谈并发、压力、吞吐量

本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/580d914e07b7fc1c26a0cf7c 前言 随着部门业务的拓展,我们有了很多性能测试的机会,但在实战中...

腾讯Bugly ⋅ 2016/10/24 ⋅ 1

甲骨文11.9亿美元收云解决方案供应商Aconex

  【IT168 资讯】根据外媒报道,澳大利亚云解决方案供应商Aconex周一宣布,已经收到美国软件巨头Oracle发出的15.6亿澳元(约合11.9亿美元,79.3亿元人民币)的现金收购要约,相当于每股7.80澳...

it168网站 ⋅ 2017/12/18 ⋅ 0

Oracle 收购 Xsigo,为软件定义网络(SDN)热火上浇油

前一周 VMware以12.6亿美元收购软件定义网络(SDN)的领军人物Nicira,上一周SDN初创企业Contrail Systems又获得1000万美元的融资。本周一Oracle宣布收购Xsigo再度为这股SDN热潮火上浇油。这...

oschina ⋅ 2012/07/31 ⋅ 3

Java 社区目前的现状 —— 交易

这是关于一笔交易的故事。 没有人为交易签过字。 但这仍然是一笔重要的交易。 这是Java的主人和Java社区之间的交易。 交易 这是我对Java的主人和Java社区之间如何相互影响作用的观点: Java...

红薯 ⋅ 2011/01/11 ⋅ 5

关于cocos2d-x几种画图方法的用法与思考

CCRenderTexture 自己的理解 CCRenderTexture类似一张空白的“画布“,用户通过自定义笔刷(CCSprite*),在touch事件中把笔刷的移动痕迹“记录”起来,从而“画”出各种艺术效果。记录方法很简...

于赟 ⋅ 2012/11/18 ⋅ 0

JAVA 支付宝退款接口

构建表单参数 批次号格式:yyyyMMddHHmmss+数字或字母 笔数:笔/订单 退款详细参数:支付宝订单号^金额^备注(多笔退款的话用#号分割) JAVA支付宝退款接口实例

周田 ⋅ 2016/04/28 ⋅ 0

在MS SQL Server数据库批量查看表的大小的三种方法

1.查看单表大小: spspaceused '表 ' 如果不写表名,就是看整个库的! 2.察看数据库所有表的大小: 方法一:内置存储过程法: EXEC spMSforeachtable @command1="print '?'",@command2="sp_sp...

桃_91 ⋅ 2013/12/26 ⋅ 0

性能测试中TPS和并发用户数

并发用户数:是指现实系统中操作业务的用户,在性能测试工具中,一般称为虚拟用户数(Virutal User)。 并发用户数和注册用户数、在线用户数的概念不同, 1、并发用户数一定会对服务器产生压力...

hxlb2012 ⋅ 2017/07/31 ⋅ 0

性能测试中TPS和并发用户数

并发用户数:是指现实系统中操作业务的用户,在性能测试工具中,一般称为虚拟用户数(Virutal User)。 并发用户数和注册用户数、在线用户数的概念不同, 1、并发用户数一定会对服务器产生压力...

hxlb2012 ⋅ 2017/07/31 ⋅ 0

Oracle 收购PaaS服务提供商Engine Yard少量股份

去年正式宣称自己为云公司的Oracle现在开始变得更加名正言顺—今天这家公司正式宣布收购平台即服务(PaaS)提供商Engine Yard的少量股权,但具体份额并未透露。 Engine Yard是一家领先的平台...

oschina ⋅ 2012/11/13 ⋅ 2

没有更多内容

加载失败,请刷新页面

加载更多

下一页

如何使用serverchan微信推送告警

之前实现推送告警信息到微信的方法有如下几种: 1、通过企业公众号实现----收费: 2、通过QQ邮箱,在微信平台上开启收到邮件进行提醒; 3、第三方告警平台API,一般也是收费的; 不过最近看文...

问题终结者 ⋅ 27分钟前 ⋅ 0

TCP的RPC

RPC就是远程方法调用(Remote Process Call ),包含了客户端和服务端,涉及了对象的序列化传输。 1.服务端启动,注册远程调用的类2.客户端发送请求信息包含类、方法、参数的一些信息、序列化传...

Cobbage ⋅ 48分钟前 ⋅ 0

IOS-UI UI初步代码布局添加事件

ISO开发界面,UI是必须学习的一部分,其实很早之前想学来了,一直没有沉下心来学习。看到IOS的代码风格和布局就别扭的不行,跟java代码和android布局比较显得不是那么方便,所以一直到现在。...

京一 ⋅ 58分钟前 ⋅ 0

浅谈OpenDaylight的二次开发

OpenDaylight作为一款开源SDN网络控制器,依托于强大的社区支持以及功能特性,成为了目前主流的SDN网络控制器开发平台。在比较稳定的OpenDaylight Helium版本中,已经为开发者提供了大量的网...

wangxuwei ⋅ 今天 ⋅ 0

API 开发中可选择传递 token 接口遇到的一个坑

在做 API 开发时,不可避免会涉及到登录验证,我使用的是jwt-auth 在登录中会经常遇到一个token过期的问题,在config/jwt.php默认设置中,这个过期时间是一个小时,不过为了安全也可以设置更...

等月人 ⋅ 今天 ⋅ 0

Java NIO之文件处理

程序要操作本地操作系统的一个文件,可以分为以下三个部分: 对文件位置的操作 对文件的操作 对文件内容的操作 其中,对文件内容的操作在 Java NIO之Channel 中已经有了介绍,通过FileChann...

士别三日 ⋅ 今天 ⋅ 0

Maven的pom.xml配置文件详解

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.......

小海bug ⋅ 今天 ⋅ 0

解决httpclient超时设置不生效的问题

最近公司有项目需要通过http调用第三方服务,且第三方服务偶有超时,故需要设置一定的超时时间防止不响应的情况出现。 初始设置如下: [java] view plain copy //超时设置 RequestConfig re...

Mr_Tea伯奕 ⋅ 今天 ⋅ 0

过滤器Filter和拦截器HandlerInterceptor

过滤器 依赖于servlet容器。在实现上基于函数回调,可以对几乎所有请求进行过滤,但是缺点是一个过滤器实例只能在容器初始化时调用一次。使用过滤器的目的是用来做一些过滤操作,获取我们想要...

hutaishi ⋅ 今天 ⋅ 0

Redis入门详解(转)

Redis入门详解 Redis简介 Redis安装 Redis配置 Redis数据类型 Redis功能 持久化 主从复制 事务支持 发布订阅 管道 虚拟内存 Redis性能 Redis部署 Redis应用场景 Redis总结 Redis简介: Redi...

xiaoyaoyoufang ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部