Oracle数据库学习第一天

1.了解Orcale数据库

  • Orcale数据库的优点
    1. 性能非常的好
    2. 安全性高,满足ISO标准
    3. 对分布式的支持非常好

2.orcale数据库的安装

  • 安装前的准备

    1. 保证有足够的磁盘空间
    2. 保证有足够的内存空间(关闭软件:360,防火墙)
    3. 两个压缩文件一起解压缩到一个目录下面
  • 解锁scott用户

    1. 首先使用管理员登录(system)
    2. 输入登录密码 system/orcl;或者conn sys as sysdba 超级管理员
    3. 解锁scott用户 alert user scott account unlock;

3.Oracle数据库服务

  1. 打开服务器的窗口

    fuwu.png
    • 打开服务窗口->控制面板->服务->Oracle
    • OracleOraDB11g_home1TNSListener:监听器服务,如果启动了监听器服务之后,用户就可以使用客户端连接Oracle数据库
    • OracleServiceORCL:Oracle核心服务,如果需要访问Oracle数据,就必须要启动该服务.

4.连接Oracle数据库

  1. 使用SQLPlus工具连接Oracle数据库
    • SQLPlus是Oracle数据库自带的一个命令行的管理工具
    • 输入命令和密码后,如果看到SQL就表示登录成功了
sqlplus.png
  1. 使用SQL-Developer工具
    工具启动之后:
  1. 创建一个新的连接
lianjie.png

注意:如果没有启动监听器服务OracleOraDB11g_home1TNSListener的话,就会连接失败

5.使用JDBC访问数据库

  1. 导入数据库的驱动包
  2. 注册驱动(在JDBC4.0之后可以自动加载驱动了,可以省略这一步)
  3. 获取数据库连接对象
  4. 获取到执行SQL语句的对象Statement对象
  5. 执行查询
  6. 处理结果集
  7. 释放资源(Connection;Statement;ResultSet)
  • 代码:

          package com.itheima.jdbc;
          import java.sql.Connection;
          import java.sql.DriverManager;
          import java.sql.ResultSet;
          import java.sql.SQLException;
          import java.sql.Statement;
          public class Demo1 {
          
              public static void main(String[] args) {
                  // jdk1.7自动资源回收
                  // 放在小括号中的流对象和连接对象对象可以自动回收
                  try (
                  // 获取数据库的连接对象
                  Connection conn = DriverManager.getConnection(
                          "jdbc:oracle:thin:@localhost:1521:orcl", "scott", "tiger");
                  // 创建Statement对象
                          Statement stmt = conn.createStatement();
                          // 执行查询
                          ResultSet rs = stmt.executeQuery("select * from emp");
          
                  ) {
                      // 遍历结果集
                      if (rs != null) {
                          while (rs.next()) {
                              System.out.println("员工编号" + rs.getInt("empno") + "员工姓名:"
                                      + rs.getString("ename"));
                          }
                      }
          
                  } catch (SQLException e) {
                      e.printStackTrace();
                  }
              }
          }
    
  • 结果

              员工编号7369员工姓名:SMITH
              员工编号7499员工姓名:ALLEN
              员工编号7521员工姓名:WARD
              员工编号7566员工姓名:JONES
              员工编号7654员工姓名:MARTIN
              员工编号7698员工姓名:BLAKE
              员工编号7782员工姓名:CLARK
              员工编号7788员工姓名:SCOTT
              员工编号7839员工姓名:KING
              员工编号7844员工姓名:TURNER
              员工编号7876员工姓名:ADAMS
              员工编号7900员工姓名:JAMES
              员工编号7902员工姓名:FORD
              员工编号7934员工姓名:MILLER
    

5.sqlplus的常用命令

  1. 格式化命令
命令 说明
set line n 设置每一行的字符数,默认是每一行显示80个字符
set pagesize n 设置每一页的记录数,默认是显示14行数据,包括了(标题,分隔线,空行)
set feedback off/on 隐藏查询状态信息/不隐藏;就是是否隐藏数据库给回的反馈信息.
col 列名 for 格式 设置某一列的格式,如果该列的数据类型是数值型,可以设置数字的格式,例如col sal for $999,999,999,如果该列数据是字符串,那么就可以用来设置字符串的宽度;例如col dname for a50;
  • 如果在sqlPlus中设置命令,该命令只在当前的窗口中有效,如果要设置全局属性,就可以在glogin.sql文件中进行设置
![sqlplus2.png](http://upload-images.jianshu.io/upload_images/3493621-fc175192454c2e65.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
  1. 其他命令
命令 说明
show all 查询系统中的所有参数
show xxx 查询系统中的指定的参数
conn 用户名/密码 切换用户
-- /**/ 单行注释和多行注释
/ 用来执行缓冲区里面最后一条sql语句
ed 将缓冲区中最后一条sql语句读取到一个文本文件中,用户可以对sql语句进行编辑,编辑并保存后sqlplus会把编辑后的sql语句重新放回到缓冲区中
spool 文件路径[apoend] 假脱机命令:他的作用是把spool命令到spool off之前的命令保存到一个文件中;如果加上了append,就不会覆盖原来的文件,如果不加上就会覆盖原来的文件
spool off 他的作用是把spool命令到spool off之前的命令保存到一个文件中
host cls 清屏
exit 退出sqlPlus

6.DDL语句 (数据库定义语言)

6.1 创建表

  1. 语法格式:

     create table 表名 (
             列名 数据类型 [primary key],
             列名 数据类型 [not null],
             ....
             constraint 约束名 约束类型(列名),
             constraint 约束名 约束类型(列名)
         );
         说明:Oracle数据库的约束类型 unique;foreign key;check;primary key;not null;
         注意:在Oracle数据库中是没有auto_increment关键字的如果要实现主键列的自增长,
         Oracle提供了一个序列的对象
    
    • 创建表示例

                -- 创建tb_user表
                create table tb_user (
                  id number(4) primary key,
                  name varchar2(20) not null,
                  gender nchar(1) default '男',
                  deptno number(4),
                  constraint uni_user_name unique(name),
                  constraint chk_user_gender check(gender in ('男','女')),
                  constraint fk_user_dept foreign key(deptno) references dept(deptno)
      

    );

  1. Oracle的数据类型
数据类型 说明
Number(p,s) 数值型(包括了整数和小数)参数p:数值的长度;参数s:数值的小数位数;
例如number(5,2);Number(5,-2) 表示的是7位整数9999900 Number(5) 9999表示的是整数
varcahr2(n) 可变长度的字节型,按照字节进行计算,
最大长度是4000字节,例如varchar2(4)
例如创智播客有8个字节
nvarchar2(n) 可变长度的字符型,按照字符进行计算,最大长度是2000个字符,一个中文2个字符
date 日期型
timestamp 时间类型
char(n) 固定长度的字符型 char(1)表示的是一个字节
nchar(n) 固定长度的字符型,按照字符进行计算;nchar(1)表示的是一个字符
CLOB 大文本数据类型;按照字节进行计算,最大可以存储4GB的字节
NCLOB 大文本数据类型,按照字符进行计算,最大可以存储2GB的字符
BLOB 二进制的数据类型
  1. 复制表
    • 语法格式:
      create table 表名
      as
      select 列名 form 表名[where 条件]
- 代码:
            -- 创建一个emp表的备份表(复制表的结构和数据)
                create table emp_bak
                as
                select * from emp;
                
                -- 复制表的结构
                create table emp_bak2
                as
                select * from emp where 1=2;
  1. 修改表

    • 添加列

    • 语法:alter table 表名 add(列名,数据类型 [not null]...)

      alter table tb_user add(sal number(7,2));

    • 修改列的类型

    • alter table 表名 modify(列名 数据类型[not null])

      alter table tb_user modify(sal number(10,2));

    • 删除列

    • 语法:alter table 表名(列名);

      alter table tb_user drop(sal);

    修改列的名字

    • -语法 alter tbale 表名 rename column 列名 to 新列名

      alter table tb_user rename column gender to sex;

  1. 删除表
    • 语法格式: drop table 表名[purge]
    • 说明:如果没有指定purge参数,那么删除的表就会保存到回收站中

      drop table emp_bak2; 把表放到回收站里面

      drop table emp_bak purge; 永久性的删除表

7.DML(数据操作语言)

  1. 添加数据

    • 语法格式:insert into 表名(列名...) values (值...)
      insert into tb_user values(1,'狗娃','男',10);
    • 注意:在Oracle中,一个insert语句只能够插入一条数据.
  2. 复制数据

    • 语法结构:insert into 表名 select 列名 form 表名(注意没有as)
      insert into emp_bak select * from emp;
    • 注意:复制数据的时候,两张表的字段数量和类型必须要相同
  3. 修改数据

    • 语法结构:update 表名 set 列1=值1;列2=值2....where 条件

      update emp_bak set ename='狗哥' where empno=7902;

  4. 删除数据

    • 语法格式:delete from 表名 where 条件;

    • 删除表的所有数据:truncate table 表名

    • delete与truncate的区别:

delete命令:是先查询,然后在删除;truncate命令是直接把表销毁了直接截断,然后重新创建了一个新的表.有外键的情况下,delete删除不了,truncate是可以直接删除的.

trancate命令比delete的执行效率要高

8.DQL(数据库查询语言)

  1. 多表查询

    • 多表查询就是同时对两个表或者是两个以上的表进行查询.
    • 注意事项:
      1).执行多表查询的时候,一个表的数据会和另外一个表的数据进行一个组合,会产生新的数据,这种现象叫做笛卡尔积.select * from emp e,dept d
      2).笛卡尔积会产生很多的垃圾数据.
      3)如果需要消除笛卡尔积只需要添加一个连接条件就可以了:一个表的外键列=另外一个表的主键列;select * from emp e,dept d where e.deptno = d.deptno;
  2. 多表查询分类

    • 一般分为内连接查询和外连接查询
    • 内连接:也称之为等值连接,执行多表查询的时候,只有满足条件的数据才会被查询出来,这个条件也被称之为等值查询.
    • 外链接:外连接一般是分为左外连接和右外连接
      1)左外连接:左边的表是主表,无论条件是否满足,主表的数据都会被查询出来.
      语法结构:select 列名 ..from 表1 left join 表2 on 表1.列名=表2.列名
      常用的写法:select * from emp e left join dept d on e.deptno = d.deptno;
      Orcale特有的写法:select 列名 from 表1,表2 where 表1.列名=表2.列名(+)
      注意:没有+号的表就是主表
      2)右外连接:右表的表是主表,无论条件是否满足,主表的数据都会被查询出来.
      常用的写法:select * from emp e right join dept d on e.deptno = d.deptno;
      Oracle特有的写法:select * from emp e,dept d where e.deptno(+) = d.deptno;
  3. 子查询

    • 子查询:在一个查询中嵌套另外一个查询.
      select * from emp where sal > (select avg(sal) from emp);

    • 如何判断select语句中子查询的位置?
      按照子查询返回的结果进行判断:

        1)单行单列的结果:可以作为一个where条件来使用:就是子查询结果为一个结果,
        单行单列常见的情况是在查询聚合函数中
            
        -- 查询工资大于10部门最高工资的员工信息
        select max(sal) from emp where deptno=30;--2850
        select * from emp where sal > (select max(sal) from emp where deptno=30);
        注意:子查询一定要放在圆括号里面.
      
      
        2)返回一个单行多列的结果集:可以作为where条件
      
        -- 查询职位和部门编号与scott用户的职位和部门编号相同的员工信息
        -- 查询SCOTT用户的职位和部门编号
        select job,deptno from emp where ename='SCOTT';
        select * from emp where (job,deptno)=(select job,deptno from emp where ename='SCOTT');  
      
      
        3)多行单列:可以作为一个where条件
      
        --查询所在地是NEW YORK的员工信息;子查询结果为多行单列
        select deptno from dept where loc='NEW YORK';
        select * from dept where deptno in (select deptno from dept where loc='NEW YORK');
      
        
        4)多行多列:可以放在from的后面,作为一个临时表
        
        --查询所有员工的姓名、职位、工资、部门平均工资。
        select avg(sal) from emp group by deptno -- 查询所有员工的姓名,职位,工资,部门的平均工资
        select ename,job,sal,a.avgSal from (select avg(sal) avgSal from emp where deptno = emp.deptno) a,emp
      
        
        5)问题:子查询是否可以放在select的后面呢?是可以的,但是很少使用
                
        --查询所有员工的姓名、职位、工资、部门平均工资。
        select ename,job,sal,(select avg(sal) from emp e1 
        where e1.deptno=e2.deptno) from emp e2
      
  4. 分组查询

    • 语法结构:select 分组字段或者是聚合函数 from 表名 where 条件 group by 分组字段 having 分组条件.

    • where条件与having条件的区别:
      1).where条件在分组前就可以确定
      2)having条件是分组后才可以确定的条件.

        --需求:查询每一个部门工资小于2000的员工人数;查询前就知道结果了
        select deptno,count(*) from emp where sal<2000 group by deptno
        
        --需求:查询每一个部门工资小于2000的员工人数,但是人数必须要大于1个人:只有查询后才知道结果
        select deptno,count(*) from emp where sal<2000 group by deptno having count(*)>1
      
    • select语句 select; from; gorup by; order by; having; where

    • 执行的顺序:from > where > group by > having > select >order by

            //注意:由于select比having后执行,所以having处的count(*)不可以使用别名,但是order by可以使用别名
            select deptno,count(*) as con from emp where sal<2000 group by deptno having count(*)>1 order by con desc;
      

9.总结

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

推荐阅读更多精彩内容

  • 5.多表查询 多表查询 目的:从多张表获取数据 前提:进行连接的多张表中有共同的列 等连接 通过两个表具有相同意义...
    乔震阅读 1,218评论 0 0
  • 1.简介 数据存储有哪些方式?电子表格,纸质文件,数据库。 那么究竟什么是关系型数据库? 目前对数据库的分类主要是...
    乔震阅读 1,712评论 0 2
  • 查询是数据的一个重要操作。用户发送查询请求,经编译软件变异成二进制文件供服务器查询,后返回查询结果集给用户,查询会...
    产品小正阅读 1,377评论 0 2
  • SQL ==SQLPLUS== DML(Data Manipulation Language,数据操作语言)---...
    蝌蚪1573阅读 588评论 0 4
  • mysql数据库中 :database : 文件夹table : 数据表(数据文件) 进入mysqlmysql -...
    赋闲阅读 559评论 0 0