oracle DML与DDL

news2024/11/18 17:44:32

一、数据库语言介绍

DML(数据库操作语言):其中包括
insert/delete/update/select等操作。

DDL(数据库定义语言):其中包括create/alter/drop等操作。

区别:1、DDL是针对数据库对象(例如:table,function,view,procedure,triger)等的定义。DML是对数据库对象的操作,例如对数据库表的增删改查等等。2、DDL作为数据库定义语言是不能进行rollback(回滚),提交方式也是隐性提交。而DML是可以进行rollback的,并且对于事务(transaction)的提交是显式的(默认),可以设置为隐式提交。


 

二、DDL与DML语法介绍

数据库对象:表(table),索引(index),视图(view),触发器(Trigger),存储过程(procedure),用户(user),函数(function)。

DDL:

例如:

1、创建一张orcl_table表:create table orcl(id int,name varchar);

2、创建一个orcl_view视图:create view orcl_view as select * from orcl_table;

注意:在数据库中视图本身是不存储对象的,是引用数据库表的查询,可以理解为是数据库表联合查询的一个超链接或者认为是一种快捷方式,一旦引用的表的数据发生变化,那么视图中的结果集也会发生变化,而且视图效率较低,视图存在的意义是将复杂查询封装,方便程序员的查询使用。

3、创建orcl_index索引(索引是优化中的重要一环):create index orcl_index on table table.cloumn。索引是作用于表的某一列或者某些列,可以提升查询的效率。

4、创建orcl_procedure存储过程:create procedure orcl_procedure (par1,par2,......),存储过程的好处在于,编译一次,多次执行,可以有效减少网络传输,提升效率,可以将存储过程理解为程序块。

5、创建orcl_function函数:create function orcl_function,函数有返回值,可以接受输入参数,经过函数体进行运算后返回结果给调用者,因为oracle函数是非常丰富的,基本可以满足99%的开发需求,因此在我的从业经验中,几乎没有写过自定义函数。

6、oracle非常大的一个优势就在于用户权限的管理,创建用户一般是由项目中的DBA人员进行创建并分配权限,跟日常开发关系不大,这里就不再赘述。

还有诸如alter等的DDL操作,在后边的分享中会一一介绍。


 

DML:

例如:

1、select

select * from orcl_table;(返回orcl_table中的所有数据)。工作中99%的开发任务都与select密切关联。

2、insert

①insert into orcl_table(column1,column2,...) values(value1,value2,....),如果不写column则代表表中的每一个字段都插入值。

②insert into orcl_table select statement;(使用子查询的结果插入到表中,工作中较常用)

3、update

update orcl_table set orcl_table.comlum = value(用得较少,也可以将子查询的结果更新到表中去)。

4、delete

delete from orcl_table where conditions;(删除符合条件的数据)。where条件可选,如果不加则删除所有数据。


 

总结:以上的②③④的操作都是需要提交事务才会以数据块的方式写入到磁盘中,因此以上操作都是可以回滚的(有犯错的余地),但是提醒大家,做这种敏感操作的时候一定要小心。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/111145.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【安全学习】apache通告中的漏洞描述

分析 漏洞描述 我们可以看看在apache通告中对漏洞的简单的描述 很明显,从这个漏洞描述中,我们能够明白这个CVE的造成主要是因为dubbo中内置的hessian项目,主要是因为在中的及以前版本中存在有这个漏洞hessian-lite3.2.12 来看看是因为哪里…

3. 请求

1. 请求映射路径 RequestMapping注解 名称:RequestMapping类型:方法注解 类注解位置:SpringMVC控制器方法定义上方作用:设置当前控制器方法请求访问路径,如果设置在类上统一设置当前控制器方法请求访问路径前缀范例 …

Matter理论介绍-通用-1-03:桥接器-数据结构

【源码、文档、软件、硬件、技术交流、技术支持,入口见文末】 【所有相关IDE、SDK和例程源码均可从群文件免费获取,免安装,解压即用】 持续更新中,欢迎关注! 一、简介 Bridge(桥接器)存在的意…

springboot集成webstock实战:服务端数据推送数据到客户端实现实时刷新

背景 之前介绍过springboot集成webstock方式,具体参考: springboot集成websocket实战:站内消息实时推送 这里补充另外一个使用webstock的场景,方便其他同学理解和使用,废话不多说了,直接开始!简单介绍一下业务场景: 现在有一个投票活动,活动详情中会显示投票活动的参与人数…

【代码随想录】二刷-贪心算法

贪心算法 《代码随想录》 什么是贪心? 贪心的本质是选择每一阶段的局部最优,从而达到全局最优。 贪心没有规定的套路。 刷题或面试的时候,手动模拟一下感觉可以局部最优退出整体最优,而且想不到反例,那么就试一试贪心。…

Python游戏开发之Dungeon Crawler 游戏源码大全

源码一 功能: WASD 移动 SPACE 攻击 SHIFT 使用楼梯 介绍 每个级别都包含一把钥匙和一个上锁的舱口。收集钥匙以解锁通往下一层的通道(SHIFT解锁)。 史莱姆造成的伤害最小,但每一层都会产生更多。他们可以降低健康或 XP。更多 XP = 每次攻击造成更多伤害。硬币目前没有…

OpenCV 读取、显示和保存图像

目录 一、OpenCV 读取图像 OpenCV 读取函数 参数: 二、OpenCV 显示图像 imshow函数 imshow函数功能 imshow函数原型 三、OpenCV 保存图像 四、结果和代码 一、OpenCV 读取图像 OpenCV 允许我们对图像执行多种操作,但要做到这一点,需…

云原生之使用Docker部署Python应用

云原生之使用Docker部署Python应用一、检查系统版本1.检查系统 版本2.检查系统内核二、检查docker状态三、编辑python文件1.创建目录2.编辑test.py文件四、构建镜像1.编辑dockerfile文件2.使用dockerfile构建镜像五、运行镜像容器1.运行python_app容器2.查看容器状态六、访问Py…

java大学校园饭卡管理系统饭卡查询系统饭卡挂失网站源码

springboot开发的大学生饭卡系统,学生可以登录该系统充值饭卡,挂失饭卡,取消挂失,查看自己的所有饭卡,以及发卡的充值记录。超级管理员拥有最大的权限,饭卡管理员可以添加饭卡信息,充值&#xf…

如何将敏捷开发与V模型深度融合?这家企业给出答案

随着汽车智能化的快速发展,消费者对智能汽车的需求正在发生变化,车企开始思考如何能快速满足消费者的这些需求。这也对汽车供应商提出更大挑战,Tier 1不仅应该具备提供相应高质量产品的量产能力,更要快速满足主机厂和用户对汽车智…

【MySQL基础教程】图形化界面工具介绍、安装与使用

前言 本文为 【MySQL基础教程】图形化界面工具介绍、安装与使用 相关介绍,下边将对图形化界面工具介绍,DataGrip的安装与DataGrip的使用进行详尽介绍~ 📌博主主页:小新要变强 的主页 👉Java全栈学习路线可参考&#x…

八、Express框架 安装

对于Express框架的就不进行过多介绍,Express官方对该框架的定位是:"基于Node.js平台,快速、开放、极简的 Web 开发框架",本篇开始记录关于 Node.js 轻量级Web开发框架 :Express框架,下面先进行Ex…

高可用架构和系统设计经验

导语 | 本文从研发规范层面、应用服务层面、存储层面、产品层面、运维部署层面、异常应急层面这六大层面去剖析一个高可用架构和系统需要有哪些关键的设计和考虑。 一、高可用系统架构设计思想 1-1、可用性和高可用概念 可用性是一个可以量化的指标,计算的公式在维…

刷爆力扣之亲密字符串

刷爆力扣之亲密字符串 HELLO,各位看官大大好,我是阿呆 🙈🙈🙈 今天阿呆继续记录下力扣刷题过程,收录在专栏算法中 😜😜😜 该专栏按照不同类别标签进行刷题,…

基于VUE学生选课管理系统

开发工具(eclipse/idea/vscode等):idea 数据库(sqlite/mysql/sqlserver等):mysql 功能模块(请用文字描述,至少200字): 一、登录注册模块: 1.学生,教师,管理员三个角色(同一时刻,账户…

Incorporating Dynamic Semantics into Pre-Trained Language Model for ABSA 论文阅读笔记

一、作者 Kai Zhang、Kun Zhang、Mengdi Zhang、Hongke Zhao、Qi Liu、Wei Wu、Enhong Chen School of Data Science, University of Science and Technology of China School of Computer Science and Information Engineering, Hefei University of Technology Meituan …

移动端Swiper的一些尝试(中间完整,两边有内容,循环展示)

【背景】最近公司的需求很多实现一个Swiper滑块,中间完整。两边展示一些内容(可能是固定的提示方案,也可能是前后上下一页的部分内容),然后还需要循环滚动,其中遇到了一些问题特此记录 1、实现两边展示内容…

Canvas 从进阶到退学

本文简介 点赞 关注 收藏 学会了 接着 《Canvas 从入门到劝朋友放弃(图解版)》 ,本文继续补充 canvas 基础知识点。 这次我不手绘了! 本文会涉及到 canvas 的知识包括:变形、像素控制、渐变、阴影、路径 变形 这…

向量杂记(python)

以 O 点为圆心, 绘制如上图, 则有向量 vOA, vOB, vOC, vOD 再给定一个X轴方向的单位向量 vX [1, 0] 则 向量 vOA, vOB, vOC, vOD 分别与 vX 进行叉乘: # python 代码 # X Y 轴上的单位向量 vX [1, 0] vY [0, 1]vA …

Matter理论介绍-通用-1-05:桥接设备-发现与配置流程

【源码、文档、软件、硬件、技术交流、技术支持,入口见文末】 【所有相关IDE、SDK和例程源码均可从群文件免费获取,免安装,解压即用】 持续更新中,欢迎关注! 一、桥接设备的发现 桥接设备如何被其他Matter终端发现呢…