Oracle日积月累

LES01-------------------------------------------------------------------------------------------------------------------------------------:

NULL:表示未提供数据;

NULL不是0也不是空格;N

解决NULL问题:函数NVL:转换NULL为实际值

定义列别名:  作用:修改列标题

                        定义列别名:可以直接跟在列名后,或加AS关键字

                        如果列别名包含有空格、特殊字符或区分大小写,那么用双引号括起来

           例子:

                1.  select ename NAME, 12*sal+nvl(comm,0)  "Annual Salary"  from  emp WHERE  ename='KING'

连接操作符:||

                    作用:连接列或字符串到其它列

            例子:

               select ename || ' ' || 'is a' || ' ' || job  as  "Employee Details"  from   emp;

删除重复行:

               select   distinct deptno  from   emp;

LES02-------------------------------------------------------------------------------------------------------------------------------------:

字符串和日期值用单引号括起来;

字符值区分大小写;

日期值区分格式,语言;

<>:不等于;

BETWEEN...AND...:在两值之间

IN(list):匹配于列表中的任一个值

LIKE:匹配于字符模式

LIKE操作符:用于执行模糊检索  %:表示零或多个字符;_:表示一个字符

逻辑操作符:AND 如果条件都是TRUE,则返回 TRUE ;

                      OR 如果任一个条件是TRUE,则返回TRUE;

                      NOT 如果条件是FALSE,则返回 TRUE;

ORDER BY子句:排序   ASC(默认):升序; DESC:降序

                              ORDER BY是SELECT语句的最后一条子句

LES03-------------------------------------------------------------------------------------------------------------------------------------:

大小写转换函数:LOWER('SQL Course'):sql course

                             UPPER('SQL Course'):SQL COURSE

                             INITCAP('SQLCourse'):Sql Course

TO_CHAR函数: select to_char(sal,'$99,999') salary  from emp where ename = 'SCOTT';

                               結果: $3,000

TO_NUMBER:转换字符串为数字

TO_DATE:转换字符串为日期

一NVL(表达式1,表达式2)

如果表达式1为空值,NVL返回值为表达式2的值,否则返回表达式1的值。该函数的目的是把一个空值(null)转换成一个实际的值。其表达式的值可以是数字型、字符型和日期型。但是表达式1和表达式2的数据类型必须为同一个类型。

    对数字型: NVL( comm,0);

    对字符型 NVL( TO_CHAR(comm), 'No Commission')

    对日期型 NVL(hiredate,' 31-DEC-99')

    例子:

    select ename,NVL(TO_char(comm),ename||' is not a salesperson!') AS COMMISSION  from emp

NVL2(表达式1,表达式2,表达式3)

如果表达式1为空,返回值为表达式3的值。如果表达式1不为空,返回值为表达式2的值。

例如 NVL2(comm,'sal+comm',sal)

NVL2函数测试comm,如果comm为空,就返回sal 的值。如果 comm 不为空(null),就返回表达式 sal+comm的值。

NULLIF函数:

  NULLIF(Expression1,Expression2):给定两个参数Expression1和Expression2,如果两个参数相等,则返回NULL;否则就返回第一个参数。

case表达式 与decode函数:

    select ename,sal,case when deptno=10 then 'dept10'

                      when deptno =20 then 'dept20' 

                      when deptno =30 then 'dept30' 

                      else 'other' end department    FROM   employees

     用decode改写

            select ename,sal,

           decode(deptno,10,'dept10',20,'dept20',30,'dept30','other') department  from emp;

LES04-------------------------------------------------------------------------------------------------------------------------------------:

Oracle  外连接(OUTER JOIN)

左外连接(左边的表不加限制)

右外连接(右边的表不加限制)

全外连接(左右两表都不加限制)

对应SQL:LEFT/RIGHT/FULL OUTER JOIN。 通常省略OUTER关键字, 写成:LEFT/RIGHT/FULL JOIN。

在左连接和右连接时都会以一张A表为基础表,该表的内容会全部显示,然后加上A表和B表匹配的内容。 如果A表的数据在B表中没有记录。 那么在相关联的结果集行中列显示为空值(NULL)。

对于外连接, 也可以使用“(+) ”来表示。 关于使用(+)的一些注意事项:

(+)操作符只能出现在WHERE子句中,并且不能与OUTER JOIN语法同时使用。

 当使用(+)操作符执行外连接时,如果在WHERE子句中包含有多个条件,则必须在所有条件中都包含(+)操作符。

(+)操作符只适用于列,而不能用在表达式上。

(+)操作符不能与OR和IN操作符一起使用。

(+)操作符只能用于实现左外连接和右外连接,而不能实现完全外连接。

    例子:

            左外连接  select * from t_A a left join t_B b on a.id = b.id;

                            或  Select * from t_A a,t_B b where a.id=b.id(+);

            右外连接  select * from t_A a right join t_B b on a.id = b.id;

                            或 Select * from t_A a,t_B b where a.id(+)=b.id;

LES05-------------------------------------------------------------------------------------------------------------------------------------:

使用group by分组查询

LES06-------------------------------------------------------------------------------------------------------------------------------------:

子查询

LES07-------------------------------------------------------------------------------------------------------------------------------------:

LES08-------------------------------------------------------------------------------------------------------------------------------------:

使用以下SQL*Plus命令可以定义用户变量

DEFINE:建立 CHAR类型用户变量

ACCEPT:读取用户输入,并存储到变量中

        如果使用DEFINE命令定义变量包含空格,则必须用单引号引住

SET: 设置当前会话环境

SHOW :显式环境设置

SET命令变量:

                ARRAYSIZE {20 | n}

                COLSEP  {_ | text}

                FEEDBACK   {6 | n |OFF | ON}

                HEADING  {OFF | ON}

                LINESIZE  {80 | n} 

                LONG  {80 | n}

                PAGESIZE  {24 | n}

                PAUSE  {OFF | ON | text}

               TERMOUT  {OFF | ON}

LES09-------------------------------------------------------------------------------------------------------------------------------------:

LES10-------------------------------------------------------------------------------------------------------------------------------------:

使用 ALTER TABLE语句:

        增加新列

        修改已存在列

        定义新列的默认值

DROP TABLE 删除表

RENAME 修改对象名

TRUNCATE 截断表

COMMENT 增加注释

LES11-------------------------------------------------------------------------------------------------------------------------------------:

约束有以下五种类型

        NOT NULL

        UNIQUE

        PRIMARY KEY

        FOREIGN KEY

        CHECK:定义每行数据必须满足的条件

                        定义CHECK约束有以下限制

                       不允许引用伪列CURRVAL、NEXTVAL、LEVEL和ROWNUM

                       不允许调用函数SYSDATE、UID、USER和 USERENV

LES12-------------------------------------------------------------------------------------------------------------------------------------:

建立视图:限制数据库访问;简化复杂查询

建立复杂视图:CREATE VIEW dept_sum_vu(name, minsal, maxsal, avgsal) AS SELECT d.dname, MIN(e.sal), MAX(e.sal),AVG(e.sal) FROM emp e, dept d WHERE e.deptno = d.deptno GROUP BY d.dname;

LES13-------------------------------------------------------------------------------------------------------------------------------------:

建立索引:CREATE INDEX index ON table (column[, column]...);

                    CREATE INDEX emp_ename_idx ON emp(ename);

删除索引:DROP INDEX emp_ename_idx;

LES14-------------------------------------------------------------------------------------------------------------------------------------:

控制用户访问 :  建立用户

                            建立角色简化安全管理

                            使用GRANT和REVOKE授予和收回权限

LES15-------------------------------------------------------------------------------------------------------------------------------------:

PL/SQL块结构:DECLARE(可选)

                                        变量、游标、自定义例外

                            BEGIN (必须)

                                        SQL 语句

                                        PL/SQL语句

                            EXCEPTION(可选)

                                        发生错误执行操作

                            END; (必须)

定义变量:按照命名惯例定义变量名

                   指定NOT NULL强制初始化变量

                   使用:=或DEFAULT可以初始化变量

                   每行只能定义一个变量

LES16-------------------------------------------------------------------------------------------------------------------------------------:

单行注释:- -

多行注释: /* 和*/

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,772评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,458评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,610评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,640评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,657评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,590评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,962评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,631评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,870评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,611评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,704评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,386评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,969评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,944评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,179评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,742评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,440评论 2 342

推荐阅读更多精彩内容

  • 1.简介 数据存储有哪些方式?电子表格,纸质文件,数据库。 那么究竟什么是关系型数据库? 目前对数据库的分类主要是...
    乔震阅读 1,699评论 0 2
  • 5.多表查询 多表查询 目的:从多张表获取数据 前提:进行连接的多张表中有共同的列 等连接 通过两个表具有相同意义...
    乔震阅读 1,194评论 0 0
  • 第一章SQL 1.Oracle数据库基础 (1).开始>运行>输入:sqlpusw/nolog>确定sqlplus...
    蛋炒饭_By阅读 291评论 0 0
  • 幕课oracle学习笔记 --!!!scott用户 --一.分组查询 --1.常用的分组函数:AVG(平均数),S...
    xiaoxiao苏阅读 1,251评论 0 5
  • 在物联网(IOT)A to Z - I中,我们从一个公用设施行业用户-燃气集团的角度进行了物联网通讯技术选择的逻辑...
    Alexliye阅读 742评论 0 3