/* DML -- 数据操纵预言: insert/delete/update */

#一: 插入语句
/*
语法1: insert into 表名(列名,..,列名....)
values(值1,值2,...),(值1,值2,...),(值1,值2,...);
语法2: insert into 表名
set 列名1=值1,列名2=值2,....;
*/
/*二: 修改语句 1.修改单表的记录
语法: update 表名
set 列1=新值1,列2=新值2,列2=新值2...
where 筛选条件 ; #如果省略,结果就是对全部数据进行了操作 2.修改多表的记录[补充]
SQL92语法:
update 表1 别名,表2 别名
set 列1=新值1,列2=新值2,列2=新值2...
where 连接条件
and 筛选条件; SQL99语法:
update 表1 别名
inner/left/right join 表2 别名
on 连接条件
set 列=值,...
where 筛选条件; */
#二: 修改语句
/*
1.修改单表的记录
语法: update 表名
set 列1=新值1,列2=新值2,列2=新值2...
where 筛选条件 ; #如果省略,结果就是对全部数据进行了操作 2.修改多表的记录[补充]
SQL92语法:
update 表1 别名,表2 别名
set 列1=新值1,列2=新值2,列2=新值2...
where 连接条件
and 筛选条件; SQL99语法:
update 表1 别名
inner/left/right join 表2 别名
on 连接条件
set 列=值,...
where 筛选条件;
*/
#三 删除条件
/*
方式1:delete
语法:
1.单标删除
delete from 表名 where 筛选条件
2.多表的删除
SQL92 语法:
delete 表1的别名,表2的别名...
from 表1 别名,表2 别名
where 连接条件
and 筛选条件;
SQL99 语法:
delete 表1的别名,表2的别名...
from 表1 别名
inner/left/right join 表2 别名
on 连接条件
where 筛选条件;
方式2:truncate语句
清空table数据 : truncate table; #不可以加任何条件
----------------------------
两者的区别和联系:
1.使用where 筛选条件
2.整表删除效率
3.面对自增长列, 用delete清空数据后,再插入数据,自增列从断点开始(删前的最大序号);
用truncate清空数据后,再插入数据,自增长列从0开始;
4.delete 删除,有返回值;可以回滚;
truncate删除,无返回值; 不能回滚; */ #1.插入的values值的类型与列的一致或兼容
INSERT INTO beauty (id,NAME,sex,borndate,phone)
VALUES(13,'唐艺昕','女','1990-4-23',''); #2.可以为null 的列可以不用插入,插入顺序可以颠倒,但必须一一对应,剩余所有列为默认值(NULL等) INSERT INTO beauty (id,NAME,borndate,sex)
VALUES(14,'娜扎','1990-4-23','女'); #3:可以省略列名,默认需要插入所有的列的信息,而且顺序和表中数据信息一致
INSERT INTO beauty
VALUES(15,'信小呆','女','1998-9-14','',NULL,NULL); #---------------------
#4.方法2
INSERT INTO beauty
SET id=16,NAME='刘涛',sex='女'; #表间插入
INSERT INTO beauty(NAME,phone) #从boy表选择全部数据插入beauty表
SELECT boyname,''
FROM boys;
#再删除上面的插入的数据
DELETE
FROM beauty
WHERE phone=''; #2 修改多表的数据 #案例1 :修改张无忌的女朋友们的手机号都为114
UPDATE boys bo
INNER JOIN beauty b
ON bo.`id`=b.`boyfriend_id`
SET b.`phone`=''
WHERE bo.`boyName`='张无忌'; #案例 2:修改没有男朋友的女生的男朋友的编号都为2号
UPDATE boys bo
RIGHT JOIN beauty b
ON bo.`id`=b.`boyfriend_id`
SET b.`boyfriend_id`=2
WHERE bo.`id` IS NULL; #3 多表的删除
#案例1: 删除张无忌的女朋友的信息
DELETE b
FROM beauty b
INNER JOIN boys bo
ON b.`boyfriend_id` = bo.`id`
WHERE bo.`boyName`='张无忌';

MySQL进阶10--DML数据操纵预言: insert/delete/update --多表连接修改/.多表连接删除/多表连接查询-- truncate 和 delete的区别的更多相关文章

  1. MySQL 详细解读undo log :insert undo,update undo

    转自aobao.org/monthly/2015/04/01/ 本文是对整个Undo生命周期过程的阐述,代码分析基于当前最新的MySQL5.7版本.本文也可以作为了解整个Undo模块的代码导读.由于涉 ...

  2. MySQL进阶13--常见六大约束: 非空/默认/主键/唯一约束/检查约束/外键约束--表级约束 / 列级约束

    /* MySQL进阶13 常见六大约束: 1.not null 非空 2.default :默认值,用于保证该字段的默认值 ; 比如年龄:1900-10-10 3.primary key : 主键,用 ...

  3. Mysql教程:(六)修改语句、、删除语句、字符查询like

    1.修改语句 update 表名 set  where 条件 mysql> update student set birth=1988,department='中文系' where id=901 ...

  4. mysql基础篇 - 数据库及表的修改和删除

    基础篇 - 数据库及表的修改和删除         修改和删除 一.实验简介 本节实验中,我们将学习并实践如何对数据库的内容做修改,删除,重命名等操作. 二.实验准备 在正式开始本实验内容之前,需要先 ...

  5. drop与truncate与delete的区别与联系

    在mysql和oracle数据库中delete与truncate都是可以用来对数据进行删除操作,但是二者又有些不同. 主要有以下几个区别: 区别一: 根据sql语言分类来说,delete属于DML语言 ...

  6. sqlite中的replace、insert、update之前的区别

    本文转自http://www.ithao123.cn/content-933827.html,在此感谢作者 android数据库操作,有两种方式,一种用android提供给我们的数据库操作函数inse ...

  7. ES6-map数据结构,增加、删除、查找 方法(set get has delete clear ) 属性:size

    map数据结构: 本质上是键值对的集合,类似集合: 可以遍历,方法很多,可以跟各种数据格式转换. let json = { name:'ananiah', age:'18' } //效率低 需要遍历j ...

  8. JDBC基础篇(MYSQL)——使用statement执行DML语句(insert/update/delete)

    注意:其中的JdbcUtil是我自定义的连接工具类:代码例子链接: package day02_statement; import java.sql.Connection; import java.s ...

  9. python3 速查参考- python基础 9 -> MySQL基础概念、数据库create、alter、insert、update、delete、select等基础命令

    前置步骤: 下载一个绿色版的mysql数据库客户端连接工具 :http://wosn.net/821.html mysql平台为win7(以后会有CentOS上的) 学习目的: 掌握数据库的基本概念, ...

随机推荐

  1. H310C,B365,M.2 NVME SSD,USB3.0,安装 WIN7 64 位

    华擎H310CM ITX NVME SSD 上安装WIN7 64位 核心关键点:xHCI USB3.0驱动,nvme驱动,nvme win7补丁. 硬件配置:I5 9400F, 华擎H310CM IT ...

  2. Android持久化存储——(包含操作SQLite数据库)

    <第一行代码>读书手札 你可能会遇到的问题:解决File Explorer 中无显示问题 Android中,持久化存储,常见的一共有三种方法实现 (一.)利用文件存储 文件存储是Andro ...

  3. 剑指offer48:不用加减乘除做加法

    1 题目描述 写一个函数,求两个整数之和,要求在函数体内不得使用+.-.*./四则运算符号. 2 思路和方法 位运算符:两个数异或(^)[1^0=1, 1^1=0, 0^0=0, 0^1=1, 5^5 ...

  4. vs2017环境下python包的安装

    1)---vs已经下载了的才适用 1,鼠标放在右侧窗口python环境那里(如没有窗口,可点击最上方的“窗口”-“重置窗口”) 2,右键然后点击“查看所有python环境”,会弹出当前默认的环境(高亮 ...

  5. A Story of One Country (Hard) CodeForces - 1181E2 (分治)

    大意: 给定$n$个平面上互不相交的矩形. 若一个矩形区域只包含一个矩形或者它可以水平或垂直切成两块好的区域, 那么这个矩形区域是好的. 求判断整个平面区域是否是好的. 分治判断, 可以用链表实现删除 ...

  6. 安利一下stringstream

    关于实用的 stringstream 处理毒瘤输入数据 比如这个题 在输入的时候有很多问题,如果用scanf输入char型字符串,那么不好用map判断,并且读入整行判断换行会很麻烦 如果选择用stri ...

  7. .net SHA-256 SHA-1

    Framework 4.5 uses SHA-256 algorithm for the signature, and 4.0 uses SHA-1.

  8. Mybatis之日志工厂

    思考:我们在测试SQL的时候,要是能够在控制台输出 SQL 的话,是不是就能够有更快的排错效率? 如果一个 数据库相关的操作出现了问题,我们可以根据输出的SQL语句快速排查问题. 对于以往的开发过程, ...

  9. Python——pip的安装与使用

    pip 是 Python 包管理工具,该工具提供了对Python 包的查找.下载.安装.卸载的功能.目前如果你在 python.org 下载最新版本的安装包,则是已经自带了该工具.Python 2.7 ...

  10. 最近跟进一个CS项目,用到c#基础知识,准备开个分类记录一下

    C#在txt类文件中追加内容 string path = "test.txt";FileStream mystream = new FileStream(path, FileMod ...