目录
MySQL/Oracle数据库
首页 数据库 mysql教程 MySQL/Oracle数据库的基础(二)

MySQL/Oracle数据库的基础(二)

Jun 07, 2016 pm 02:50 PM
mysql oracle 基础 数据库

MySQL/Oracle数据库 Oracle数据库管理系统是管理数据库访问的计算机软件,由Oracle数据库与Oracle实例构成 Oracle数据库:一个相关的操作系统文件集合,这些文件组织在一起,成为一个逻辑整体,即为Oracle数据库。Oracle数据库必须要与内存实例合作,才能对外提供

MySQL/Oracle数据库

  • Oracle数据库管理系统是管理数据库访问的计算机软件,由Oracle数据库与Oracle实例构成
    • Oracle数据库:一个相关的操作系统文件集合,这些文件组织在一起,成为一个逻辑整体,即为Oracle数据库。Oracle数据库必须要与内存实例合作,才能对外提供数据管理服务。
    • Oracle实例:位于物理内存里的数据结构,它由操作系统的多个后台进程和一个共享的内存池所组成,共享的内存池可以被进程锁访问。
      • Oracle用它们来管理数据库访问
      • Oracle实例就是平常所说的数据库服务(service)
    • 实例可以操作数据库;在任何时刻一个实例只能与一个数据库关联,访问一个数据库;同一个数据库可由多个实例访问(RAC)
  • Oracle区别于MySQL的:
    • 在Oracle数据库中,使用NUMBER表示数字类型、DATE表示日期类型、VARCHAR2表示字符类型
  • 空值不同于0,凡是空值参与的运算,结果都为空(null),空值是无效的,未指定的
  • 别名的创建:(方式三)
  • 使用双引号”“,如:将别名原封不动的显示(尤其是别名由多个单词构成)

    <code>select employee_id "id",last_name "Name",12*salary "annual_sal"
    from employees;
    </code>
    登录后复制
  • 连接符:

    • 把列与列,列与字符连接在一起
    • 用”||”来连接
    • 可以用来“合成”列
    • 如:

      <code>select first_name || ' ' || last_name from employees;
      </code>
      登录后复制
  • 字符串:
    • 字符串可以是select列表中的一个字符、数字、日期
    • 日期和字符只能在【单引号】中出现
    • 每当返回一行时,字符串被输出一次
  • 使用distinct能够过滤掉重复的数据,如:

    <code>select distinct dept_id from empt;
    </code>
    登录后复制
  • SQL语句与SQL*Plus命令:
    • SQL:一种语言、ANSI标准、关键字不能缩写、使用语句控制数据库中的表的定义和表中的数据。
    • SQL*Plus:一种环境、Oracle的特性之一、关键字可以缩写(如:edit(ed)、describe(desc))、命令不能改变数据库中的数据的值、集中运行
  • 数据库操作函数:

    • 单行函数

      • 单行函数分类:字符、数值、日期、转换、通用

        <code>单行函数:①操作数据对象;
                ②接收参数返回一个结果
                ③只对一行进行变换
                ④每行返回一个结果
                ⑤可以嵌套与转换数据类型
                ⑥参数可以是一列或一个值
        </code>
        登录后复制
      • 字符函数:

        • 字符大小控制函数,如:

          <code>LOWER('HELLOWORLD')             //helloworld
          UPPER('hello')                  //HELLO
          initcap('helloWorld you')       //Helloworld You,首个字母大写
          </code>
          登录后复制
        • 字符控制函数,如:

          <code>CONCAT('Hello', 'World')        //HelloWorld
          SUBSTR('HelloWorld',1,5)        //Hello
          LENGTH(('HelloWorld')           //10
          INSTR('HelloWorld','W')     //6
          LPAD(24000,10,'*')              //*****24000
          RPAD(24000,10,'*')              //24000*****
          TRIM('H' FROM 'HelloHWorldH')   //elloHWorld
          REPLACE('abcd','b','m')     //amcd
          </code>
          登录后复制
      • 数值函数:

        • round:四射五入

          <code>round(45.926,2)     //45.93
          round(45.926,-1)    //50
          </code>
          登录后复制
        • trunc:截断

          <code>trunc(45.926,2)     //45.92
          </code>
          登录后复制
        • 求余:

          <code>MOD(1600,300)       //100
          </code>
          登录后复制
      • 日期函数:
        • Oracle中的日期型数据实际含有两个值:日期和时间
          • 日期:函数sysdate返回
          • 两个日期相减返回日期之间相差的天数(但是不允许做加法运算)
        • MONTHS_BETWEEN:两个日期相差的月数
        • ADD_MONTHS:向指定日期中加上若干月数
        • NEXT_DAY:指定日期的下一个星期*对应的日期
        • LAST_DAY:本月的最后一天
        • ROUND:日期四舍五入
        • TRUNC:日期截断
      • 转换函数:

        • 隐性(Oracle自动完成下列转换)

          <code>VARCHAR2 or CHAR ---------------------> NUMBER
          VARCHAR2 or CHAR ---------------------> DATE
          NUMBER  ------------------------------> VARCHAR2
          DATE    ------------------------------> VARCHAR2
          </code>
          登录后复制
        • 显性

          • DATA→to_char()→CHARACTER→to_date()→DATE

            <code>select to_char(sysdate,'yyyy-mm-dd') from dual;
            select to_date('1995-05-23', 'yyyy-mm-dd') from dual;
            //在用到字符时使用双引号,如:
            select to_char(sysdate,'yyyy"年"mm"月"dd"日"') from dual;
            </code>
            登录后复制
          • NUMBER→to_char()→CHARACTER→to_number()→NUMBER

            <code>//1,234,567.890,'$999,999,999,999.999'表示美元,
            //'L999,999,999,999.999',表示当地货币符(L表示local)
            select to_char(1234567.89,'999,999,999,999.999') from dual;
            select to_number('Y001,234,567.89','L000,000,999.99') from dual;
            </code>
            登录后复制

            在数值的转化中,to_char()函数经常使用的集中格式:

            <code> - 9:数字
             - 0:零
             - $:美元符
             - L:本地货币符号
             - .:表示小数点
             - ,:表示千位符
            </code>
            登录后复制
      • 通用函数:

        • 该类函数适用于任何数据类型,同时也适用于空值
        • NVL(expr1,expr2):

          • 将空值转换成一个已知的值
          • 可以使用的数据类型有日期、字符、数值
          • 函数的形式:

            <code>NVL(commission_pct, 0)  //表示为当commission_pct为null时其值为0,否则等于commission_pct
            NVL(hire_date,'01-JAN-97')
            </code>
            登录后复制
        • NVL2(expr1,expr2,expr3):expr1不为NULL,返回expr2;为NULL,返回expr3
        • NULLIF(expr1,expr2):相等返回NULL,不等返回expr1
        • COALESCE(expr1,expr2,…,exprn):如果第一个表达式为空,则返回下一个表达式,对其他的参数进行COALESCE.
          • COALESCE与NVL相比的优点在于COALESCE可以同时处理交替的多个值
      • 条件表达式:

        • 在SQL语句中使用IF-THEN-ELSE逻辑
        • 使用的两种方法:

          • case表达式:

            • 格式:

              <code>case expr when comparison_expr1 then return_expr1
                  [when comparison_expr2 then return_expr2
                  ...]
                  else else_expr
              end 
              </code>
              登录后复制
            • 如:

              <code>select department_id,
              case department_id when 10 then salary*1.1
                                 when 20 then salary*1.2
                                 else salary*1.3
              end
              from employees
              where department_id in(10,20,30);
              </code>
              登录后复制
        • decode函数:

          • 如:

            <code>select department_id,
            decode(department_id, 10, 1.1*salary,
                                  20,1.2*salary,
                                  30,1.3*salary)
            from employees;
            </code>
            登录后复制
  • 嵌套组函数:

    • 如:显示各部门平均工资中的最大值

      <code>select max(avg(salary))
      from employees
      group by department_id;
      </code>
      登录后复制
  • Oracle数据库子查询:

    • 子查询语法:

      <code>select select_list
      from table
      where expr operator(
          select select_list2
          from table2;        //table与table2可以是同一个表
      );
      </code>
      登录后复制
    • 子查询在主查询之前一次执行完成,子查询的结果被主查询使用
    • 注意:

      <code>1.子查询要包括在括号内
      2.将子查询放在比较条件的右侧
      3.子查询中可以使用组函数
      4.子查询中要留意空值
      </code>
      登录后复制
    • 单行子查询使用的单行比较操作符:

      <code>=、>、>=、(不等于)
      </code>
      登录后复制
      • 如:

        <code>select salary,last_name
        from employees
        where salary > (select salary
                        from employees
                        where last_name='Abel');
        </code>
        登录后复制
    • 多行子查询使用的多行操作符:

      <code>如:in、any(和子查询返回的某一个值比较)、all(和子查询返回的所有值比较)
      </code>
      登录后复制
    • 综合子查询嵌套

      <code>            //查询平均工资最低的部门信息
      select *
      from departments
      where department_id = (select department_id
                             from employees
                             group by department_id
                             having avg(salary) = (select min(avg(salary))
                                                   from employees
                                                   group by department_id
                                                  )
                             )
      </code>
      登录后复制
  • 创建和管理表(DDL)(create、alter、drop、rename、truncate)→操作皆不可回滚

    • Oracle数据库中的表

      • 用户定义的表

        • 用户自己创建并维护的一组表
        • 包含了用户所需的信息
        • 常用的查询字典命令:

          <code>select * from user_tables;  //查看用户创建的表有哪些
          select table_name from user_tables; //查看用户创建的表的表名
          select distinct object_type from user_objects;  //查看用户定义的各种数据库对象
          select * from user_catalog;     //查看用户定义的表,视图,同义词和序列
          </code>
          登录后复制
      • 数据字典
        • 由Oracle Server自动创建的一组表
        • 包含数据库信息
    • 创建表的方式:

      • 方式一:直接创建空表

        <code>create table myemploy(
            id number(5),
            name varchar2(20),          //注意:定义字符串使用的是varchar2
            salary number(10,2),        //表示10位数据,其中两位是小数
            hire_date date
        );
        </code>
        登录后复制
      • 方式二 :使用子查询创建表

        • 指定的列和子查询中的列要一一对应
        • 通过列名和默认值定义列

          <code>//方式二:从其他的表中抽取部分列生成新表
          create table empt
          as 
          select employee_id,last_name,salary,hire_date
          from employees;
          
          //注意,上表生成的信息会把原来的表中的数据也复制过来,若想不生成
          数据,则可加上不等的过滤条件,如:
              create table employee
              as 
              select employee_id,last_name,salary,hire_date
              from employees
              where 1=3;              //因为2不可能等于3,故创建的表为有相应结构而无数据的空表
          </code>
          登录后复制
  • 数据处理(DML)(insert into、delete from、upddate、select)→操作可回滚

    • 插入数据的特殊方式:从其他表中拷贝数据,如:

      <code>insert into emp(employee_id,last_name,salary,hire_date)
      select employee_id,last_ame,salary,hire_date
      from employees
      where employee_id </code>
      登录后复制
    • 创建脚本:在SQL语句中使用&变量指定列值,&变量放在values子句中,如:

      <code>//该插入方法是在执行语句后来添加数据的
      insert into emp(employee_id,last_name,salary,hire_date)
      values(&employee_id,'&last_name',&salary,&hire_date);
      </code>
      登录后复制

      -update:update不加限制条件更新的是整个列的数据

    • 在update中,可以使用子查询时更新基于另一个表中的数据,如:

      <code>    upadate emp_copy
          set departmen_id = (select departmen_id
                              from employees
                              where employee_id = 20
                              )
          where job_id = (select job_id
                          from employees
                          where employee_id = 10
                          );
      </code>
      登录后复制
    • 数据增删改查相关的操作
      • commit(提交):类似于文件保存
      • rollback(回滚):当操作数据不当时,可以通过回滚回到修改前的数据
    • 数据库事务:

      • 以第一个DML语句的执行作为开始
      • 以下面的其中之一作为结束:

        • commit或rollback语句

          <code>commit与rollback语句的优点:
              1.确保数据完整性
              2.数据改变被提交之前预览
              3.将逻辑上相关的操作分组
          在进行增删改操作时可以设置保存点,如:
                  savepoint A;
          在未commit之前,进行多步(增删改)操作后,可以直接通过保存点回滚到保存点处,如:
              rollback to savepoint A;
          注意:回滚只能在commit之前进行,在commit之后是无效的
          </code>
          登录后复制
        • DDL语句(自动提交)
        • 用户会话正常结束
        • 系统异常终止
      • 提交或回滚前的数据状态
        • 改变前的数据状态是可以恢复的
        • 执行DML操作的用户可以通过delect语句查询之前的修正
        • 其他用户不能看到当前用户所做的改变,直到当前用户结束事物
        • DML语句所涉及到的行被锁定,其他用户不能操作
    • 数据库操作(增删改查)完成后最好执行commit。
  • Oracle数据库创建约束:

    • 非空约束(not null),如:

      <code>create table emp(
          id number(10) constraint emp_id_nn not null,    //emp_id_nn表示约束名
          name varchar(20),
          salary number(10,2)
      )
      </code>
      登录后复制
    • 唯一约束(unique),如:

      <code>create table emp(
          id number(10) constraint emp_id_uq unique,  //列级约束,emp_id_uq约束名
          name varchar(20) constraint,
          salary number(20),
          phone number(11),
          //表级约束
          constraint emp_phone_uq unique(phone)       //括号内指明约束列
      )
      </code>
      登录后复制
    • 主键约束(primary key),如:

      <code>create table emp(
          id number(5) constraint emp_id_pk primary key,
          name varchar(20),
          salary number(9,2)
          //或者使用表级约束
          //constraint emp_id_pk primary key(id)
      )
      </code>
      登录后复制
    • 外键约束(foreign key):连接两个表,将两个表进行关联

      • foreign key:在表级指定子表中的列
      • references:标示在父表中的列
      • 如:

        <code>create table empt(
            id number(5),
            name varchar(20),
            salary number(7,2),
            dept_id number(5),
            constraint emp_dept_fk foreign key(dept_id) references depts(dept_id) 
        )
        create table depts(
            dept_id number(5),
            dept_name varchar(10),
            job_id number(3)
        )
        </code>
        登录后复制
    • 删除数据时,父表中的列被删除时,子表(外键关联的)中对应的列也被删除
    • 添加约束的语法:

      • 使用alter table语句:

        <code>1.添加或删除约束,但是不能修改约束
        2.有效化或无效化约束
        3.添加not null约束要使用modify语句
        </code>
        登录后复制
      • 格式:

        <code>alter table table_name
        add(drop...) [constraint constraint_name] type (column);
        </code>
        登录后复制
      • 如:

        <code>//添加不为空
        alter table emp
        modify salary number(8,2) not null;
        //添加其他的约束
        alter table emp
        add constraint emp_uq unique(name);
        //删除约束
        alter table emp
        drop constraint emp_uq;
        //无效化约束
        alter table emp
        disable constraint emp_uq;
        //有效化(注意,enable的前提是约束所在的列不存在对应的约束问题)
        alter table emp
        enable constraint emp_uq;
        </code>
        登录后复制
    • 查询约束:

      • user_constraints
      • 如:

        <code>//查询约束名、约束类型、约束条件
        select constraint_name,constraint_type,search_condition 
        from user_constraints
        where table_name='employees';   //''其内的表示表名
        </code>
        登录后复制
      • 查询定义约束的列:

        • user_cons_columns
        • 如:

          <code>select constraint_name,column_name
          from user_cons_columns
          where table_name='employees';
          </code>
          登录后复制
  • 视图:

    • 视图是一种虚表,视图建立在已有表的基础上
    • 向视图提供数据内容的语句为SELECT语句
    • 视图的优点:
      • 控制数据访问
      • 简化查询
      • 避免重复访问相同的数据
    • 视图中使用DML的规定

      • 可以在简单视图中执行DML操作
      • 当视图定义中包含以下元素之一时不能使用delete:
        • 组函数
        • group by子句
        • distinct关联字
        • rownum伪列(表示原来表中不存在的列)
      • 如:

        <code>create or replace view emp_view
        as select
        avg(salary) avg_sal from employees
        group by department_id;
        </code>
        登录后复制
  • 序列:可供多个用户用来产生唯一数值的数据库对象

    • 自动提供唯一的数值
    • 共享对象
    • 主要用于提供主键值
    • 将序列值装入内存可以提高访问效率
    • 创建格式:

      <code>create sequence seq_name
      [increment by n]    //每次增长的数值
      [start wiht n]      //从哪个值开始
      [{maxvalue n | nomaxvalue}]
      [{minvalue n | nominvalue}]
      [{cycle | nocycle}]     //是否需要循环
      [{cache n | nocache}]   //是否缓存登录
      </code>
      登录后复制
    • 如:

      <code>create sequence emp_seq
      increment by 5
      start with 2
      maxvalue 50
      cycle
      nochche;
      </code>
      登录后复制
    • 序列的执行方法:

      <code>1.select emp_sql.nextval from dual; 
      2.select emp_sql.curval from dual;
      </code>
      登录后复制
    • 注意:首次调用方法时,需要闲滴啊用nextval.
    • 序列的修改(不能修改初始值)

      <code>alter sequence seq_name
      increment by newval
      nomaxvalue
      ...;    
      </code>
      登录后复制
    • 修改序列注意:
      • 1.必须是序列的拥有者或对序列有alter权限
      • 2.只有将来的序列值会被改变
      • 3.改变序列的’初始值’只能通过删除序列之后重新建序列的方法实现
      • 4.rollback是无法回滚序列的
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何使用 PHP 创建 MySQL 表? 如何使用 PHP 创建 MySQL 表? Jun 04, 2024 pm 01:57 PM

使用PHP创建MySQL表需要以下步骤:连接到数据库。创建数据库(如果不存在)。选择数据库。创建表。执行查询。关闭连接。

如何修复 MySQL 8.4 上的 mysql_native_password 未加载错误 如何修复 MySQL 8.4 上的 mysql_native_password 未加载错误 Dec 09, 2024 am 11:42 AM

MySQL 8.4(截至 2024 年的最新 LTS 版本)中引入的主要变化之一是默认情况下不再启用“MySQL 本机密码”插件。此外,MySQL 9.0完全删除了这个插件。 此更改会影响 PHP 和其他应用程序

iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 iOS 18 新增'已恢复”相册功能 可找回丢失或损坏的照片 Jul 18, 2024 am 05:48 AM

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

在PHP中使用MySQLi建立数据库连接的详尽教程 在PHP中使用MySQLi建立数据库连接的详尽教程 Jun 04, 2024 pm 01:42 PM

如何在PHP中使用MySQLi建立数据库连接:包含MySQLi扩展(require_once)创建连接函数(functionconnect_to_db)调用连接函数($conn=connect_to_db())执行查询($result=$conn->query())关闭连接($conn->close())

如何在PHP中处理数据库连接错误 如何在PHP中处理数据库连接错误 Jun 05, 2024 pm 02:16 PM

PHP中处理数据库连接报错,可以使用以下步骤:使用mysqli_connect_errno()获取错误代码。使用mysqli_connect_error()获取错误消息。通过捕获并记录这些错误信息,可以轻松识别并解决数据库连接问题,确保应用程序的顺畅运行。

如何使用 PHP 设置 MySQL 连接池? 如何使用 PHP 设置 MySQL 连接池? Jun 04, 2024 pm 03:28 PM

使用PHP设置MySQL连接池,可以提高性能和可伸缩性。步骤包括:1.安装MySQLi扩展;2.创建连接池类;3.设置连接池配置;4.创建连接池实例;5.获取和释放连接。通过连接池,应用程序可以避免为每个请求创建新的数据库连接,从而提升性能。

如何使用 PHP 删除 MySQL 表中的数据? 如何使用 PHP 删除 MySQL 表中的数据? Jun 05, 2024 pm 12:40 PM

PHP提供以下方法来删除MySQL表中的数据:DELETE语句:用于从表中删除匹配条件的行。TRUNCATETABLE语句:用于清空表中的所有数据,包括自增ID。实战案例:可以使用HTML表单和PHP代码从数据库中删除用户。表单提交用户ID,PHP代码使用DELETE语句从users表中删除匹配ID的记录。

Go WebSocket 如何与数据库集成? Go WebSocket 如何与数据库集成? Jun 05, 2024 pm 03:18 PM

如何将GoWebSocket与数据库集成:设置数据库连接:使用database/sql包连接到数据库。将WebSocket消息存储到数据库:使用INSERT语句将消息插入数据库。从数据库检索WebSocket消息:使用SELECT语句检索数据库中的消息。

See all articles