2018-02-19 18:03:54

一、数据操纵语言(Data Manipulation Language)

数据操纵语言是指插入,删除和更新语言。

二、视图(View)

数据库三级模式,两级映射中,使用视图可以实现外模式,可以实现数据的逻辑独立性。

视图可以分为两种:

1、普通视图(General view):使用CREATE VIEW 生成的视图,是通过基表进行运算得到的,也被称为虚表,其定义是永久保存的,其内容是临时计算的。

视图在一定程度上可以保证数据的安全性,因为可以选择呈现给用户的数据。另外,在早期,视图中的数据是不允许修改的,因为视图是一张虚表,是实际不存在的表。但是如果说能保证数据和基表的唯一对应,则可以进行修改。

2、临时视图(Temporary view and recursive query):使用WITH子句定义的临时表称为临时视图,注意其定义也是不进行保存的,可以实现递归查询。

三、嵌入式SQL

如何在程序设计语言中使用SQL呢?

主要要解决如下几个问题:

  1. 如何让程序设计语言接受SQL语句;
  2. 如何让程序和数据库如何交换消息和数据;
  3. 查询结果是一个集合,如何将其传递给程序设计语言中的变量;
  4. 数据类型的匹配问题

主要解决方法:

  1. 嵌入式SQL;
  2. 编程API(ODBC,JDBC等);
  3. 封装类库;

以C语言中的嵌入式SQL为例,其中有一些基本概念:

  1. 以 EXEC SQL 开头,分号结尾;
  2. 通过宿主变量(host variables)进行数据的交互;
  3. 在SQL中使用宿主变量需要加上:,以示区分;
  4. 有一个特殊的宿主变量SQLCA (SQL Communication Area),使用 EXEC SQL INCLUDE SQLCA 来定义;
  5. SQLCA.SQLCODE 来判别语句执行状态;
  6. indicator (short int) 来表征NULL;

首先可以定义一些宿主变量,之后通过这些宿主变量进行交互。但是,这里有一个问题就是如何对返回结果为集合的SQL语言进行数据的交互。解决方案就是很常用的cursor,游标机制。通过游标机制,可以将返回的集合看成文件进行读取。

四、动态SQL

程序运行前程序执行的SQL语句是没法确定的,所以需要使用动态SQL。先前的游标中的SELECT语句是写死的,但是实际应用中是不能这样的,经常需要运行时确定。

主要有三类动态SQL:

  1. Dynamic SQL executed directly:主要指非查询的插删改语句;
  2. Dynamic SQL with dynamic parameters:带有动态参数;
  3. Dynamic SQL for query:带有查询语句;

1)Dynamic SQL executed directly

2)Dynamic SQL with dynamic parameters

使用占位符进行带动态参数的动态SQL。

3)Dynamic SQL for query

五、存储过程

将经常使用的一组SQL语句可以存储成一个存储过程,系统可以将其进行优化存储,下次使用的时候用户就可以很方便的进行调用,不用重复编写。本质就是一种SQL语句的封装。

数据库原理及应用-SQL数据操纵语言(Data Manipulation Language)和嵌入式SQL&存储过程的更多相关文章

  1. CREATE TABLE——数据定义语言 (Data Definition Language, DDL)

    Sql语句分为三大类: 数据定义语言,负责创建,修改,删除表,索引和视图等对象: 数据操作语言,负责数据库中数据的插入,查询,删除等操作: 数据控制语言,用来授予和撤销用户权限. 数据定义语言 (Da ...

  2. 【转】Hive Data Manipulation Language

    Hive Data Manipulation Language Hive Data Manipulation Language Loading files into tables Syntax Syn ...

  3. oracle数据操纵语言(DML)data manipulation language

    数据库操纵语言(DML)用于查询和操纵模式对象中的数据,它不隐式地提交当前事务. SELECTINSERTUPDATEDELETECALLEXPLAIN PLANLOCK TABLEMERGE使用算术 ...

  4. oracle数据操纵语言(DML)data manipulation language(续集)

    SQL查询语句(SELECT)进阶分组函数(Group Functions):对多行进行操作,并为每一组给出一个结果. AVG([DISTINCT|ALL] expression) 平均值COUNT ...

  5. SQL Fundamentals || DCL(Data Control Language) || 用户管理&Profile概要文件

    SQL Fundamentals || Oracle SQL语言 语句 解释 Create user Creates a user(usually performed by a DBA) Grant ...

  6. SQL Fundamentals || DCL(Data Control Language) || 角色ROLES

    SQL Fundamentals || Oracle SQL语言 语句 解释 Create user Creates a user(usually performed by a DBA) Grant ...

  7. SQL Fundamentals || DCL(Data Control Language) || 系统权限&对象权限管理(GRANT&REVOKE)

    SQL Fundamentals || Oracle SQL语言 语句 解释 Create user Creates a user(usually performed by a DBA) Grant ...

  8. Hive 6、Hive DML(Data Manipulation Language)

    DML主要是对Hive 表中的数据进行操作的(增 删 改),但是由于Hadoop的特性,所以单条的修改.删除,其性能会非常的低所以不支持进行级操作: 主要说明一下最常用的批量插入数据较为常用的方法: ...

  9. (让你提前知道软件开发33):数据操纵语言(DML)

    文章2部分 数据库SQL语言 数据操纵语言(DML) 数据操纵语言(Data Manipulation Language,DML)包含insert.delete和update语句,用于增.删.改数据. ...

随机推荐

  1. 菜鸟也能学cocos2dx3.0 浅析刀塔传奇(下)

    首先我们讲点话外的东西,异步载入:众所周知,loading里面一般都是载入数据的,那么是怎么载入的呢? Director::getInstance()->getTextureCache()-&g ...

  2. 007-Shell test 命令,[],[[]]

    一.概述 test 命令用于检查某个条件是否成立,它可以进行数值.字符和文件三个方面的测试. 其中[]完全等价于test,只是写法不同.双中括号[[]]基本等价于[],它支持更多的条件表达式,还允许在 ...

  3. JavaWeb—基于Token的身份验证

    传统身份验证的方法 HTTP Basic Auth HTTP Basic Auth简单点说明就是每次请求API时都提供用户的username和password,简言之,Basic Auth是配合RES ...

  4. 使用DAO工厂创建实现类对象

    首先分析DAO模式中的每一部分 VO(对象实体):这个类成员变量与数据库中每个字段一一对应,同时提供了相应是set和get方法来设置或取得数值.这个类一般是通过IDE自动生成的 DAO(数据访问接口) ...

  5. python爬虫中文乱码解决方法

    python爬虫中文乱码 前几天用python来爬取全国行政区划编码的时候,遇到了中文乱码的问题,折腾了一会儿,才解决.现特记录一下,方便以后查看. 我是用python的requests和bs4库来实 ...

  6. Python(异常处理)

    一 错误和异常 程序中难免出现错误,而错误分成两种 1.语法错误(这种错误,根本过不了python解释器的语法检测,必须在程序执行前就改正) 2.逻辑错误(逻辑错误) 什么是异常 异常就是程序运行时发 ...

  7. webService 总结

    Web Service基本概念 Web Service也叫XML Web Service WebService是一种可以接收从Internet或者Intranet上的其它系统中传递过来的请求,轻量级的 ...

  8. 3.1、Ubuntu系统中jmeter的安装和目录解析

    ​以下内容亲测,如果不对的地方,欢迎留言指正,不甚感激.^_^祝工作愉快^_^ Jmeter是一个非常好用的压力测试工具.  Jmeter用来做轻量级的压力测试,非常合适,只需要十几分钟,就能把压力测 ...

  9. python3_time模块详解

    python提供的时间模块time是需要单独引入: 1.time.sleep(secs)# 推迟调用线程的运行,secs指的是秒 time.sleep(secs) 2.time.time():返回当前 ...

  10. 在vue项目中使用codemirror插件实现代码编辑器功能(代码高亮显示及自动提示

    在vue项目中使用codemirror插件实现代码编辑器功能(代码高亮显示及自动提示) 1.使用npm安装依赖 npm install --save codemirror; 2.在页面中放入如下代码 ...