本系列是作为学习笔记,用于记录学习过程,加深学习印象,以及自己重新回顾学习内容只用,参考书籍为《oracle 11g从入门到精通(第二版)》,如果需要深入学习,请购买原书籍,谢谢!

1、sql语言简介

sql全称是结构化查询语言,英文structured query language,它是一种在关系型数据库中定义和操作数据的标准语言。

1.1 sql语言特点

sql是一种非过程化语言,能让用户不用考虑诸如数据的存储格式和数据的存储路径等复杂问题就能按照自己的要求在高层数据结构上操作。

通过sql语句,程序员或者数据库管理员可以进行如下的主要工作:

  • 建立数据库的表格,比如设置表格可以使用的空间;
  • 改变数据库的系统环境变量
  • 针对讴歌数据库或者表格,赋予用户权限
  • 对数据库表格建立索引值
  • 修改数据库表格结构(新建、删除或者修改表格字段)
  • 对数据库进行数据的新建
  • 对数据库进行数据的删除
  • 对数据库进行数据的修改
  • 对数据库进行数据的查询

sql语言的特点

1)综合统一:数据库的主要功能是通过数据库支持的数据语言来实现‘

2)集合性: sql运行用户在高层的数据结构上工作,而不对单个记录进行操作,可以操作记录集。

3)统一性: sql为许多任务提供了统一的命令,方便学习;

数据库的操作任务通常包括:

  • 查询数据
  • 在表中插入、修改和删除记录
  • 建立、修改和删除数据对象
  • 控制对数据和数据对象的读写
  • 保证数据库一致性和完整性

4)高度非过程化:sql只提做什么,不提怎么做,用户无需了解存储路径及物理地址,这样减轻用户负担,提高效率。

5)语言简单,易学易用:整个sql只用9个命令动词即可实现对数据库及数据的查询和管理,如下表所示:

sql的功能 命令动词
数据定义 CREATE,DROP,ALTER
数据操作 SELECT,INSERT,UPDATE,DELETE
数据控制 GRANT,REVOKE

6)同语法结构不同使用方式: 第一种是交互式应答使用,第二种通过预编译sql进行执行。

7)是所有关系数据库的公共语言: 由于多有主要的关系型数据库管理系统都支持sql,用户可以将使用sql的部分从一个RDBMS转移到另一个,方便移植。

1.2 sql语言分类

1)数据查询语言DQL

用于检索数据库中的数据,主要是select语句

2 数据操作语言DML

用于该表数据库中的数据,主要包括INSERT、UPDATE和DELETE这3条语句

  • INSERT:用于将数据插入到数据库中
  • UPDATE:用于更新数据库中已经存在的数据
  • DELETE: 用于删除数据库中已经存在的数据

3)事务控制语言TCL

用于维护数据的一致性,包括COMMIT、ROLLBACK和SAVEPOINT这3条语句

  • COMMIT:用于提交对数据库的修改
  • ROLLBACK:用于取消对数据库的修改
  • SAVEPOINT: 用于设置保存点

4) 数据定义语言DDL

用于建立、修改和删除数据库对象。如:使用CREATE TABLE语句创建表;使用ALTER TABLE语句修改表结构;使用DROP TABLE语句删除表;

5) 数据控制语言DCL

用于执行权限授予和权限回收操作,主要包括GRANT和REVOKE

  • GRANT 给用户或角色授予权限
  • REVOKE 回收用户或角色所具有的权限

1.3 sql语言的编写规则

1) sql关键字不区分大小写,可以使用大写格式、小写格式或者大小写混用,如:


select empno,ename,sal from scott.emp;
SELECT empno,ename,sal FROM scott.emp;
SELect empon,ename,sal FRom scott.emp;

以上三条语句均是可行的,是一样的效果。

2) 对象名和列名不区分大小写,可以使用大写,小写,大小写混用


select empno,ename,sal from scott.emp;
select EMPNO,ENAME,SAL from SCOTT.EMP;
select EMPno,ename,sAL from scott.emp;

以上三条语句均是可行的,且是一样的效果

3)字符值区分大小写,sql中应用字符值时,大小写不同


select * from scott.emp where job = 'SALESMAN';
select * from scott.emp where job = salesman;

查询结果不一致。

4)sql语句较长时,可以分行编写,当sql语句输入完毕,以分号结束即可。

2、用户模式

在Oracle中,为了便于管理用户所创建的数据库对象(如数据表、索引、视图等),引入模式概念,这样某个用户所创建的数据库对象就都属于该用户模式。

2.1 模式与模式对象

模式是一个数据库对象的合集,为数据库用户所有。模式与所创建用户同名,一个模式内部不能之积分访问其他模式的数据库对象,在拥有访问权限的情况下,也需要指定模式的名称才能访问其他模式的数据对象。

是由用户创建的逻辑结果,用于存储和应用数据。如段(segment)或者用户用有的其他数据对象,包括约束、试图、同义词、过程、程序包等。

2.2 实例模式scott

Oracle提供的scott模式,就是给用户提供一些实例表和数据来展示oracle数据库的一些特性。

该模式演示了一个很简单的公司人力资源管理的数据结构。查询数据字典视图USER_TABLES可以获得该模式所包含的数据表

学习笔记:oracle学习三:SQL语言基础之sql语言简介、用户模式的更多相关文章

  1. UNP学习笔记(第三章:套接字编程简介)

    本章开始讲解套接字API. 套接字地址结构 IPv4套接字地址结构 它以sockaddr_in命名,下面给出它的POSIX定义 struct in_addr { in_addr_t s_addr; } ...

  2. 【Unity Shaders】学习笔记——SurfaceShader(三)BasicDiffuse和HalfLambert

    [Unity Shaders]学习笔记——SurfaceShader(三)BasicDiffuse和HalfLambert 转载请注明出处:http://www.cnblogs.com/-867259 ...

  3. Introduction to 3D Game Programming with DirectX 12 学习笔记之 --- 第三章:变换

    原文:Introduction to 3D Game Programming with DirectX 12 学习笔记之 --- 第三章:变换 学习目标 理解如何用矩阵表示线性变换和仿射变换: 学习在 ...

  4. 20155234 2016-2017-2第十周《Java学习笔记》学习总结

    20155234第十周<Java学习笔记>学习总结 教材学习内容总结 网络编程 在两个或两个以上的设备(例如计算机)之间传输数据.程序员所作的事情就是把数据发送到指定的位置,或者接收到指定 ...

  5. java JDK8 学习笔记——助教学习博客汇总

    java JDK8 学习笔记——助教学习博客汇总 1-6章 (by肖昱) Java学习笔记第一章——Java平台概论 Java学习笔记第二章——从JDK到IDEJava学习笔记第三章——基础语法Jav ...

  6. 20155234 2610-2017-2第九周《Java学习笔记》学习总结

    20155234第九周<Java学习笔记>学习总结 教材学习内容总结 数据库本身是个独立运行的应用程序 撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的增删查找 JDBC(Ja ...

  7. #学习笔记#e2e学习使用(二)

    前言: <#学习笔记#e2e学习使用(一)>主要记录了Vue项目的创建到e2e环境的搭建,以及期间遇到的各种问题和解决方法.本文建立在基础测试环境搭建完毕能正确运行的情况下,编写测试代码, ...

  8. python3.4学习笔记(七) 学习网站博客推荐

    python3.4学习笔记(七) 学习网站博客推荐 深入 Python 3http://sebug.net/paper/books/dive-into-python3/<深入 Python 3& ...

  9. #学习笔记#e2e学习使用(一)

    本文仅限于记录本人学习的过程,以及怎么踩的坑,是如何解决的.逻辑肯定是混乱的,有用之处会抽出共通另行发帖. 最终目标:要运用于Vue项目中,进行功能测试甚至自动化测试. 一.e2e概念 理解:end ...

随机推荐

  1. UOJ188. 【UR #13】Sanrd [min_25筛]

    传送门 思路 也可以算是一个板题了吧qwq 考虑min_25筛最后递归(也就是DP)的过程,要枚举当前最小的质因子是多少. 那么可以分类讨论,考虑现在这个质因子是否就是次大质因子. 如果不是,那么就是 ...

  2. layui select多选下拉显示 以及回显

    <input type="hidden" id="hiddensheshi" name="hiddensheshi" value=&q ...

  3. mysql in()后子查询优化

    线上数据发现一条数据大量等待的现象,通过explain发现这个sql写法存在问题,这里简单记录一下. 业务场景是这样: 存在购物车和费用两张表,购物车数据是购买商品时生成,用于记录购买商品数据,同时购 ...

  4. GAN 原理及公式推导

    Generative Adversarial Network,就是大家耳熟能详的 GAN,由 Ian Goodfellow 首先提出,在这两年更是深度学习中最热门的东西,仿佛什么东西都能由 GAN 做 ...

  5. 深入理解JVM虚拟机13:再谈四种引用及GC实践

    Java中的四种引用类型 一.背景 Java的内存回收不需要程序员负责,JVM会在必要时启动Java GC完成垃圾回收.Java以便我们控制对象的生存周期,提供给了我们四种引用方式,引用强度从强到弱分 ...

  6. go中的方法以及自定义类型代码示例

    package main import "fmt" type user struct { name string age int sex string } type admin s ...

  7. postman_

    form-data 相当于Content-Type:multipart/form-data;它会将表单的数据处理为一条消息,以标签为单元,用分隔符分开.既可以上传键值对,也可以上传文件. x-www- ...

  8. HTML5中的article和section的区别

    HTML5中的article和section的区别 一.总结 一句话总结: article和section都相当于语义化后的div,article强调独立性,section强调分段或者分块 1.art ...

  9. Cannot start compilation: the output path is not specified for module "salesystem". Specify the output path in Configure Project.

    错误是发生在从github上checkout自己的项目时.因为没有将配置文件一起上传,所以在运行java程序时有了这个报错: Cannot start compilation: the output ...

  10. composer Changed current directory to没反应

    根据官方手册执行composer global require "laravel/installer" 显示Changed current directory to C:/User ...