对数据库的操作除了查询,还包括插入、更新和删除等数据操作。后3种数据操作使用的 SQL 语言也称为数据操纵语言(DML)。

一、插入数据(insert 语句)

  插入数据就是将数据记录添加到已经存在的数据表中,可以通过 insert 语句实现向数据表中一次插入一条记录,也可以使用 select 子句将查询结果批量插入数据表。

  1、单条插入数据

   语法:

insert into table_name [ (column_name[,column_name2]...) ] values(express1[,express2]... )
  • table_name:要插入数据的表名
  • column_name1 和 column_name2:指定表的完全或部分列名称
  • express1 和 express2 :表示要插入的值列表

      EG:

SQL > insert into dept(deptno,dname,loc) values(88,'Tony','tianjin')

       注意:

  •  insert into 中指定添加数据的列,可以是数据表的全部列,也可以是部分列
  • 给指定列添加数据时,需要注意哪些列不能空;对于可以为空的列,添加数据可以不指定值;添加数据时,还应该数据添加数据和字段的类型和范围
  • 向表中所有列添加数据时,可以省略 insert into 子句后面的列表清单,使用这种方法时,必须根据表中定义列的顺序为所有的列提供数据
  • 添加数据时,还应该注意哪个字段是主键(主键的字段是不允许重复的),不能给主键字段添加重复的值 

  2、批量插入数据

  insert 语句还可以一次向表中添加一组数据,可以使用 select 语句替换原来的 values 子句,语法如下:

insert  into  table_name [ (column_name1[,column_name2...]...) ] selectSubquery
  • table_name:要插入数据的表名
  • column_name1  和 column_name2 :表示指定的列名
  • selectSubquery:任何合法的 select 语句,其所选列的个数和类型要与语句中的 column 对应。

     EG:

SQL > insert into jobs_temp select * from jobs where jobs.salary > 1000

      注意:

  • 使用这种语句实现批量插入数据时,insert into 子句指定的列名可以与 select 子句指定的列名不同,但是它们之间的数据类型必须是兼容的

二、更新数据(update 语句)

  如果表中的数据不正确或不符合需求,那么就可以通过 update 语句实现修改现有的数据记录。

  更新数据时,更新的列数可以有自己指定,列与列之间用逗号分隔;更新的条数可以通过 where 子句来加以限制,使用 where 子句时,系统只更新符合 where 条件的记录,语法如下:

update table_name set {column_nam1=express1 [,column_name2=express2...] | (column_name1 [,column_name2...]) = (selectSubquery)} [where condition]
  •    table_name:表示要修改的表名
  • column_name1 和 column_name2 :表示指定要更新的列名
  • selectSubquery: 任何合法的 select 语句,其所选列的个数和类型要与语句中 column 对应
  • condition:筛选条件表达式,只有符合筛选条件的记录才会被更新

  EG1:

SQL > update emp set sal = sal*1.2 where job = "salesman"

    表示把销售员(salesman)的工资上调20%。

  EG2:

SQL > update emp set sal = (select avg(sal) from emp where job = "manager") where sal < 2000

    表示把emp表中工资小于2000的人员工资调整为管理者的平均工资的水平。

  注意:

  •   将 update 语句与 select 语句组合使用时,必须保证 select 语句返回单一的值,否则会出现错误提示,导致更新数据失败。

三、删除数据 (delete 语句和 truncate 语句)

  Oracle 系统提供了从数据库删除记录的功能,删除记录可以使用 delete 语句和 truncate 语句,区分如下:

  1、delete 语句

   delete  语句用来删除数据库中的所有记录和指定方位的记录,若要删除指定范围的记录,需用 where 子句进行限制,语法如下:

delete from table_name [where condition]
  • table_name:表示要删除记录的表名
  • condition:筛选条件,可选项,只有符合筛选条件的记录才会被删除掉

  EG:

SQL > delete from jobs where job_id = "pro"

   注意:使用 delete 语句来删除数据时, Oracle 系统会产生回滚记录,所有这种操作可以使用 rollback 语句来进行撤销

  2、truncate 语句

  删除记录也可以使用 truncate 语句,语法同 delete 语句,使用 truncate 语句删除表中的所有记录要比 delete 语句快得多,但是不会产生回滚记录,执行了 truncate 语句的操作也就无法使用 rollback 语句撤销。

  注意:在 truncate 语句还可以使用 reuse storage  关键字或者 drop  storage  关键字,前者表示删除记录后仍然保存记录所占用的空间;后者表示删除记录后立即回收记录所占用的空间。Oracle 系统默认情况下的 truncate 语句使用 drop storage 关键字。

Oracle 操作数据库(增删改语句)的更多相关文章

  1. 2. MongoDB基本操作 —— 用Mongo.exe操作数据库增删改查

    一.开篇 传统的关系数据库一般由数据库(database).表(table).记录(record)三个层次概念组成,MongoDB是由数据库(database).集合(collection).文档对象 ...

  2. Django-Model操作数据库(增删改查、连表结构)

    一.数据库操作 1.创建model表         基本结构 1 2 3 4 5 6 from django.db import models     class userinfo(models.M ...

  3. phpcms 操作数据库 增删改查

    数据库的其他类继承的都是libs/class/model.class.php 这里面有写好的操作数据库的常用方法 1.增 insert($data, $return_insert_id = false ...

  4. MongoDB学习day04--NodeJs操作数据库增删改查

    一.在Nodejs中使用Mongodb Nodejs需要引入的包 npm install mongodb --save -dev 或者使用镜像 cnpm install mongodb --save ...

  5. java操作数据库增删改查的小工具1--TxQueryRunner

    在java程序中,一般使用jdbc连接数据库,比较麻烦,在看传智教程时学了一个工具类,用于简化与数据库之间的操作步骤,就是TxQueryRunner,他是QueryRunner的子类,用起来和他是一样 ...

  6. JavaWeb学习记录(七)——MVC操作数据库增删改查与分页功能

    一.分页工具类 package blank.util;import java.util.List; import org.springframework.jdbc.core.JdbcTemplate; ...

  7. java操作数据库增删改查的小工具2--TxQueryRunner

    当涉及到多表查询时,如数据库中有两张表分别为t_person和t_address,表结构如下: 其中t_person的外键为t-address的主键aid, 新建两个javaBean类,Person ...

  8. 学习总结 DML数据库增删改语句

    insert into score t values('111','3-105',88)--插入一行数据 insert into score(sno,cno) values('111','3-105' ...

  9. 前端web通过flask操作数据库-增删改查

    后端python代码: #coding:utf8 from flask import Flask,request,render_template import pymysql as mysql imp ...

  10. python操作mysql数据库增删改查的dbutils实例

    python操作mysql数据库增删改查的dbutils实例 # 数据库配置文件 # cat gconf.py #encoding=utf-8 import json # json里面的字典不能用单引 ...

随机推荐

  1. 第06组 Beta冲刺(5/5)

    队名:拾光组 组长博客链接 作业博客链接 团队项目情况 燃尽图(组内共享) 组长:宋奕 过去两天完成了哪些任务 继续维护后端代码 准备beta版本的答辩 GitHub签入记录 接下来的计划 整理任务, ...

  2. Gitlab修改用户密码

    sudo gitlab-rails console production > user=User.where(name: "root").first > user.pa ...

  3. java 465端口发送邮件

    package com.fr.function; import java.io.IOException; import java.security.Security; import java.util ...

  4. Java多个线程顺序打印数字

    要求 启动N个线程, 这N个线程要不间断按顺序打印数字1-N. 将问题简化为3个线程无限循环打印1到3 方法一: 使用synchronized 三个线程无序竞争同步锁, 如果遇上的是自己的数字, 就打 ...

  5. Centos7安装golang

    标准官网:https://golang.org/ 需要墙 镜像官网:https://golang.google.cn/dl/ [国内推荐] 1.下载文件 # wget https://dl.googl ...

  6. Amazon | OA 2019 | Optimal Utilization

    Given 2 lists a and b. Each element is a pair of integers where the first integer represents the uni ...

  7. git pull的时候提示git pull <remote> <branch>

    yuanqiao@yuanqiao-PC MINGW64 /h/WorkSpace/git/dadeTest (dev)$ git pullremote: Enumerating objects: 7 ...

  8. 应用程序正常初始化(0xc0000135)失败。请单击“确定”,终止应用程序。

    应用程序正常初始化(0xc0000135)失败.请单击“确定”,终止应用程序. 没有安装对应版本的.NET FRAMEWORK.

  9. ou can mix require and export. You can't mix import and module.exports.

    ou can mix require and export. You can't mix import and module.exports.

  10. Kubernetes 监控方案之 Prometheus Operator(十九)

    目录 一.Prometheus 介绍 1.1.Prometheus 架构 1.2.Prometheus Operator 架构 二.Helm 安装部署 2.1.Helm 客户端安装 2.2.Tille ...