DML语法:

        insert  注意点:1.在表后可以有括号,表明  所插入的值是哪几列,但是一定要包括所有的not null属性
                                            2.当要为一个表插入的一行数据中有FK,先看FK的值是否存在,
                                               若不存在,则先添加外键所在表中的值,之后再插入
  1. /*
  2. * insert 添加数据
  3. * insert into tableName values('所有数据')
  4. * insert into tableName(部分列名 - 必须包含所有非空列) values('部分列数据')
  5. */
  6. insert into course values('C01', 'JavaSE', 100);
  7. insert into course values('C02', 'JavaSE', '');
  8. insert into course(courseno, coursename) values('C03', 'Oracle');
  9. --insert into course(courseno) values('C04'); -- wrong
  10. -- char固定长度
  11. insert into school values('S8372222', '中国大学');
  12. insert into school values('S8372223', '中国三美大学');
  13. insert into faculty values('01', '计算机系', 'S8372223');
  14. insert into faculty values('02', '土木工程系', 'S8372223');
  15. insert into faculty values('03', '计算机系', 'S8372222');
  16. insert into faculty values('04', '土木工程系', 'S8372222');
  17. insert into major values('M0001', '软件工程', '01');
  18. insert into major values('M0002', '网络工程', '01');
  19. insert into major values('M0003', '建筑', '02');
  20. insert into major values('M0004', '建筑美学', '02');
  21. insert into major values('M0005', '软件工程', '03');
  22. insert into major values('M0006', '网络工程', '03');
  23. insert into major values('M0007', '建筑', '04');
  24. insert into major values('M0008', '建筑美学', '04');
  25. insert into studentcard values('S87232', '中国大学', '张思思', '11级软件04班');
  26. -- insert添加 FK引入PK的值 有值直接使用 无值先insert数据再插入
  27. insert into student values('S0001', '张思思', '', null, null, '无锡', '', 'M0008', 'S87232');
  28. insert into studentcard values('S87233', '中国大学', '张珊珊', '11级软件04班');
  29. insert into student values('S0002', '张珊珊', '女', 20, null, '北京', '68', 'M0005', 'S87233');

update 注意点:update tableName set 列名 = value, ... where ...

  1. update tableName set 列名 = value, ... where ...
  2. -- 部分数据更新 where条件
  3. update student set age = 20;
  4. -- 某一条 PK UK
  5. select * from student; -- PK UK
  6. update student set name = '张三散', sex = '男' where stuNo = 'S9999';
  7. select * from course;
  8. update course set hour = 200 where courseno = 'C05';
  9. 用户登录
  10. update users set password = '123456' where userName = 'admin';
  11. update users set info = 'newInfo' where userName = 'admin';
  12. 中国大学 - 中国社会大学
  13. update school set schoolName = '中国社会大学' where schoolname = '中国大学';
  14. -- 某几条数据 FK
  15. -- 教学部 所有员工 奖金+200
  16. update employee set bonus = bonus + 200
  17. where deptNo = (select deptNo from dept where deptName = '教学部');
  18. -- 软件工程 专业学生 总+10
  19. update student set score = score + 10
  20. where majorno in (select majorNo from major where name = '软件工程');
  21. -- 计算机部 学生总分 + 5
  22. update student set score = score + 5
  23. where unionno = (select unionno from studentunion where unionname = '计算机部');
  24. -- 所有员工工资 + 500
  25. update employee set salary = salary + 500;

    delete    注意点:1.当只想删除一条记录时,where后的条件属性必须是FK  或者  UK
                               2.当一张表中有FK时,有两种方案可以删除(按具体情况使用):
                                                 a. 同时删除(例:删帖子,那么帖子下的回复内容自然同时删除了)
                                                 b.先更新再删除

  1. delete from tableName where ...
  2. -- 删除所有数据
  3. delete from course;
  4. -- 删除某一条数据 PK UK
  5. select * from course;
  6. delete from course where courseno = 'C05';
  7. 某员工辞职
  8. delete from employee where empNo = 'empNo';
  9. select * from student;
  10. delete from student where stuNo = 'S9008';
  11. 某商品下架
  12. -- 中国大学 计算机系 撤销
  13. -- 删除数据 数据FK被引用
  14. --学生
  15. update student set majorno = 'M0007'
  16. where majorno in (select majorno from major
  17. where facultyno =(select facultyno from faculty
  18. where fname = '计算机系' and schoolcode
  19. = (select schoolcode from school
  20. where schoolname = '中国大学')));
  21. --专业
  22. delete from major where facultyno = (select facultyno from faculty
  23. where fname = '计算机系' and schoolcode
  24. = (select schoolcode from school
  25. where schoolname = '中国大学'));
  26. --院系
  27. delete from faculty where fname = '计算机系'
  28. and schoolcode = (select schoolcode from school
  29. where schoolname = '中国大学');
  30. -- 同时删除
  31. 课程C01 JavaSE 100 开设有问题
  32. delete from studentcourse where courseno = 'C01';
  33. delete from course where courseno = 'C01';
  34. BBS论坛
  35. 帖子 - 回复 帖子内容有严重问题
  36. delete from reply where postId = '0001';
  37. delete from post where postId = '0001';
  38. -- 更新 再删除
  39. -- 大学毕业 学生证失效
  40. update student set cardno = null;
  41. delete from studentcard;


























DML_数据操纵语言的更多相关文章

  1. DML(数据操纵语言)

    1.概念(C) 数据操纵语言 DML (Data Manipulation Langua)是SQL语言的一个分类,用于对表的内容或者说数据进行增.删.改.查等操作. 通过以下几个关键字实现: SELE ...

  2. 数据库原理及应用-SQL数据操纵语言(Data Manipulation Language)和嵌入式SQL&存储过程

    2018-02-19 18:03:54 一.数据操纵语言(Data Manipulation Language) 数据操纵语言是指插入,删除和更新语言. 二.视图(View) 数据库三级模式,两级映射 ...

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

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

  4. MySQL之数据操纵语言(DML)

    数据操纵语言(DML) 数据操纵语(Data Manipulation Language),简称DML. DML主要有四个常用功能. 增 删 改 查 insert delete update sele ...

  5. 30442数据操纵语言DML

    5.5 SQL的数据操纵功能 5.5.1 数据插入 使用CREATE语句创建的数据表还只是一个“空壳”,表中没有任何数据.利用SQL语言提供的INSERT语句可以完成向数据表插入数据的任务. INSE ...

  6. DML 数据操纵语言

    1.INSERT(插入)语言结构 INSERT INTO table(表名)(要插入的列名) VALUES(要插入的具体值): table:要插入数据的表的表名 column[,column]:表中要 ...

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

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

  8. SQL语言学习-数据操纵语言

    一般而言,数据库中数据的生命周期包括数据插入以及更新.数据删除3个阶段.首先需要用户或者系统将数据插入表.然后,对数据的使用,包括数据的检索以及数据的更新.最后,如果数据已经没有使用价值,则将数据删除 ...

  9. DML语言(数据操纵语言)

    #DML语言/*数据操作语言:插入:insert修改:update删除:delete */ #一.插入语句#方式一:经典的插入/*语法:insert into 表名(列名,...) values(值1 ...

随机推荐

  1. Ajax条用WebService 5星级

    转:http://www.cnblogs.com/frozenzhang/p/ajax.html 随笔- 2 文章- 0 评论- 5 $.ajax()调用webservice   常规请求基本格式 [ ...

  2. ABAP 日期时间函数(转)

    转自:http://www.sapjx.com/abap-datetime-function.html 函数名称 (内页-点击名称可查看操作) 函数说明 备注 FIMA_DATE_CREATE RP_ ...

  3. oc-04-类的声明和实现

    //main.m //10-[掌握]类的声明和实现 //.h为类的声明,.m为类的实现,+表示类方法静态方法,-表示对象方法..h文件中的方法都是public不能更改的.变量3中访问域:public, ...

  4. T-SQL 之 概述

    T-SQL(Transact Structured Query Language )它是ANSI和ISO SQL 标准的Microsoft SQL Server方言或扩展,SQL SERVER专用标准 ...

  5. ie6双边距bug及其解决办法

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  6. [课程相关]homework-04

    零.准备工作 这次的作业仍然是结对编程,我们队伍的成员为:梁杰.夏天晗.谢祖三.上次我们是选择了一个时间大家聚在一起进行编程,效果不错,所以这次我们还是决定采用这种方式.由于大家平时比较忙,这周六日我 ...

  7. Call to undefined function imagettftext()解决方法

    由 老高 发表于 2014-10-03  在 代码人生 分类 老高在一个新环境中装DEDECMS的时候发现后台验证码无法显示.直接搜索一下这个错误,有人说session错误,有的说权限错误等等,这不胡 ...

  8. PHP笔试题汇总

    1.抓取远程图片到本地,你会用什么函数? fsockopen, A 2.用最少的代码写一个求3值最大值的函数. function($a,$b,$c){* W0 z* u6 k+ e. L  a: }5 ...

  9. Linux下配置Node环境变量及问题详解

    这是之前在Linux下配置Node环境变量时踩过的坑,今天又有小伙伴询问这个问题,因此记录下来,不仅是给新童鞋们一些参考,也方便日后查阅 在这之前,相信都已经安装好了,没安装的可以查看博主另一篇文章 ...

  10. SQL Server 在线进程分析处理

    SQL Server 在线进程分析处理 前言 数据库在线进程处理在很多时候需要人为干预已达到预期管理目标,下面整理一下常用的在线进程管理方法,便于后续工作使用. 一.查看目标数据库在线进程,并杀死指定 ...