先不聊技术,咱先闷骚一下。刚看完“解忧杂货店”的第二章“深夜的口琴声”,这一章勾起了我万千思绪,小说毕竟是小说,可能与现实不符,但能引发思考,反应一个普遍问题就是好小说。看到一半我还特意去酷狗上搜了一下有没有“深夜里的口琴声”里的“重生”这首歌,结果意料之中。我也在怀疑,我一直以来的那些想法是不是我的执念,就说“架构师”这事情,在大学校园里就为自己立了一个目标,在毕业后5年内达到架构师的水准,在一个大型技术型公司里能够独当一面,扛起担子,带领大家“干大事”;眼看现在时间快四年了,到2018年6月21日,工作满5年,回头看看自己的水平,远不及当初所想。假如当初克朗接受现实,回到家乡继承父业,把音乐当做一个爱好,会不会也生活得很悠闲?那这种情况下他的音乐会不会被现实中的琐事湮灭?但是按照小说里的情节,他也免不了最终的悲剧,即使是没有那场意外;因为他所定义的那种“实现梦想的人”毕竟是少数,虽然小芹的成名曲也是“重生”,但在章节开始,一个音乐评论家就说过:“歌唱得跟你一样好的人多的是,如果你的声音很有特色,自然另当别论,但你没有”;显然小芹的出名并不完全因为“重生”。看完这章,我的收获是,定个目标,但去除执念,一切慢慢来,顺其自然,但也不能发生“音乐被现实中的琐事湮灭”这种事情,毕竟“梦想是要有的,万一实现了呢!”。至于架构师呢,时间不变,等2018年6月21日回头看看自己的成效吧。以后的“架构师养成”这一标签的中的所有博客标题去掉前缀“架构师养成记--”,但还会放到“架构师养成”这一标签中。

  oracle很久之前就学过,工作中一直在用,但是都比较浅显。这次借着“架构师养成”把oracle再梳理一遍,包括最最基础的sql语句,不嫌麻烦,慢慢来。

  登录system 设置scott账户

  ALTER USER scott account unlock

  ALTER USER scott identified by orcl

一、sql基础

1、数据库语言分类

数据操作语言:DML (data manipulation language)

  select insert update delete merge

数据定义语言:DDL (data definition language)

  create alter drop turncate

事务控制语言:TCL (transaction control language)

  commit rollback savepoint

数据控制语言:DCL (data control language) 权限相关的

  grant revoke

对于oracle,DML操作会产生undo和lock(除了select)

2.数据类型

  包含 字符、数值、日期、大对象

  • char 固定字符,最大长度2000
  • varchar2 可变长,最长4000,最小1
  • number
  • date timestamp
  • clob(存储单字节数据,文本数据)
  • blob(存储二进制数据)

3.常用函数

  date char number三种类型相互之间转换

  • to_timestamp('2017-03-19 21:58:12.08','YYYY-MM-DD HH24:MI:SS.FF');对应mysql中的函数 str_to_date('2008-4-2 15:3:28','%Y-%m-%d %H:%i:%s')
  • to_date('2017-03-19','YYYY-MM-DD')
  • to_char(sysdate,'YYYY-MM-DD')
  • to_char(systimestamp,'YYYY-MM-DD HH24:MI:SS.FF');mysql中对应的函数是date_format(time, '%Y%m%d%H%i%s')
  • to_number(replace(to_char(sysdate,'YYYY-MM-DD'),'-'))

时间与字符串之间转换的详细用法可以参考博客:

http://www.cnblogs.com/reborter/archive/2008/11/28/1343195.html

  • decode函数 decode(deptno,10,'部门1',20,'部门2','部门3'); mysql中没有decode
  • case表达式 case when deptno=10 then '部门1' when deptno=20 then '部门2' else '部门3' end 或者使用 case deptno when 10 then '部门1' else '部门3' end 这种格式;mysql中也有对应表达式,mysql中海油if函数可实现类似功能。
  • trunc
  • add_months
  • month_between
  • last_day
  • replace
  • substr
  • concat
  • abs
  • round

4.分组

组函数 sum min max avg count

分组特性 group by ... having

翻译题:

1.查询每个部门的平均薪水之后显示部门平均薪水大于2000的部门编号和其平均薪水

select deptno,avg(sal) from emp group by deptno having avg(sal)>2000;

2查询每个部门的薪水和,在算出所有部门薪水平均值

select sum(sal) as total,avg(sal) as average from emp group by deptno;

5.几种连接

  • 交叉连接
  • 等值连接、非等值连接
  • 内连接

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

    select * from dept inner join emp on dept.deptno = emp.deptno

    select * from dept join emp on dept.deptno = emp.deptno

  • 外链接(左外,右外,全连接)

    select * from dept,emp where dept.deptno = emp.deptno(+)

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

    select * from dept left outer join emp on dept.deptno = emp.deptno

    select * from dept full join emp on dept.deptno = emp.deptno

  • 自连接  
  • 自然连接(隐含连接条件,自动匹配连接)

    很少用,就是两张表字段名和字段类型完全相同,oracle就自动连接。相当于一种内连接

    select * from dept natural  join emp 也就相当于 select * from dept,emp where dept.deptno = emp.deptno

  • 集合运算

    union(重复记录只返回一条)

    union all(显示所有记录)

    intersect(显示公司的数据部分)

    minus(集合相减,那个表在前面以那个表数据为主)

6.子查询

  • 非关联子查询:select * from emp where emp.deptno = (select deptno from dept where dept.deptno=10)
  • 关联子查询:select emp.ename,(select dept.dname from dept where dept.deptno=emp.deptno) as deptname from emp
  • in和exists。in是做全表扫描;exists是做是否存在,非全表扫描。

7.rownum的使用

只有用小于才能查到结果,使用大于没有结果。使用别名的形式查询,大于才有结果。

select * from (select emp.*,rownum as rn from emp ) where rn > 5;

select * from (select emp.*,rownum as rn from emp ) where rn between 5 and 10;

要注意的是,使用between and 是包含的。

这一篇就先这样了,都是一些基础的东西,不要嫌烦,再看一遍总有点收获。其他的像存储过程,函数什么的,就不多介绍了,都类似上面这些基础的东西,应该很熟练。

38.oracle开篇的更多相关文章

  1. Oracle 数据库日常巡检

    1. 检查数据库基本状况 包含:检查Oracle实例状态,检查Oracle服务进程,检查Oracle监听进程,共三个部分. 1.1. 检查Oracle实例状态 select instance_name ...

  2. 【体系结构】Oracle参数介绍

    [体系结构]Oracle参数介绍 1  BLOG文档结构图 2  前言部分 2.1  导读和注意事项 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的知识,~O(∩_∩ ...

  3. Oracle与SQL SERVER编程差异分析(入门)

    网上有关Oracle与SQL SERVER性能差异的文章很多,结论往往是让你根据数据量与预算来选择数据库.但实际项目中,特别是使用 .Net 开发的系统,支持以上两种数据库或者更多已经成为Boss的普 ...

  4. 如何解决Oracle 11g EM网站报“此网站的安全证书存在问题”

    在IE中输入https://localhost:1158/em 接报错,打不开;提示:“证书错误,此网站安全证书有问题”,解决过程如下: 1.删除与重建dbconsole 2.配置必要的环境变量 1. ...

  5. oracle 10g操作和维护手册

    1.    检查数据库基本状况... 1.1.     检查Oracle实例状态... 1.2.     检查Oracle服务进程... 1.3.     检查Oracle监听状态... 2.    ...

  6. Oracle 12C执行root.sh CLSRSC-119 CRS-8503 CLSRSC-366

    1.环境 OS:SUSE Linux Enterprise 12 SP3 X86_64 (Kernel: 4.4.162-94.69.2) DB:12.2.0.1 两节点RAC 参考文档:在 SLES ...

  7. Oracle 11g EM删除重建的方法

    虚拟机里的Oracle 11g好长时间没用了,突然打开之后发现EM无法访问了,EM可以重建,于是也不打算查找原因了,直接使大招 OS:Windows Server 2012 Oracle:11g R2 ...

  8. Linux删除oracle数据库

    手动的删除ORACLE数据库. 本人的做法: su - root lsnrctl stop kill -9 `ps -ef |grep oracle |grep -v grep |awk '{prin ...

  9. [转]Oracle 初始化参数之cursor_sharing

    本文转自:http://www.cnblogs.com/Richardzhu/archive/2013/01/21/2869837.html 一.Cursor_sharing简介: 这个参数是用来告诉 ...

随机推荐

  1. 611. Valid Triangle Number三角形计数

    [抄题]: 给定一个整数数组,在该数组中,寻找三个数,分别代表三角形三条边的长度,问,可以寻找到多少组这样的三个数来组成三角形? [暴力解法]: 全部都用for循环 时间分析: 空间分析: [思维问题 ...

  2. ROS launch启动文件的理解与编写

    博客参考:https://blog.csdn.net/weixin_41995979/article/details/81784987 和 https://www.cnblogs.com/zjiaxi ...

  3. 此实现不是Windows平台FIPS验证的加密算法的一部分

    运行wpf程序,出现错误“此实现不是Windows平台FIPS验证的加密算法的一部分”. 解决方法: 1.在window中打开功能里输入regedit,回车打开注册器: 2.进入如下路径中 HKEY_ ...

  4. Linux mmap函数简介

    一.简介 Linux提供了内存映射函数mmap, 它把文件内容映射到一段内存上(准确说是虚拟内存上), 通过对这段内存的读取和修改, 实现对文件的读取和修改, 先来看一下mmap的函数声明: 头文件: ...

  5. SOCKET句柄泄露带来的内存灾难

    前些时候游戏莫名其妙出现大量内存泄露,我感到很诧异,当然一般情况下游戏的内存管理是极其严苛的,出现如此大量的内存泄露到底是怎么回事? 句柄滥用导致的内存泄露会多夸张呢,尤其SOCKET,在某些客户端系 ...

  6. Django和Ajax

    本文目录 一 什么是Ajax 二 基于jquery的Ajax实现 三 案例 四 文件上传 五 Ajax提交json格式数据 六 Django内置的serializers(把对象序列化成json字符串) ...

  7. win2003 ent 64 + mssql ent 64

    1.打win2003补丁(取消IE8.0)2.msconfig->boot.int->高级中,将内核改成83.将cd1,cd2,高到Servers,Tools目录中,并保证Servers, ...

  8. System.Web.HttpUtility VS System.Web.HttpServerUtility VS System.Net.WebUtility

    HttpUtility 类作为 HttpServerUtility 类的内部使用,HttpServerUtility 通过System.Web.UI.Page.Server属性(WebForm)/Co ...

  9. sun.misc.BASE64Decoder的风险

    问题描述 最近需要使用Base64上传图片,但是返现sun.misc.BASE64Decoder 为已经过期的包,此包为以前sun公司的内部包,可以下载此包,但是不利于现在Maven方式构建,可能会在 ...

  10. Android-openFileInput openFileOutput

    Android设计了一套可以操作自身APP目录文件对API openFileInput openFileOutput,读取只需传入文件名,写入需要传入文件名 与 权限模式 界面: 布局代码: < ...