MySql学习笔记三
MySql学习笔记三
4.DML(数据操作语言)
插入:insert
修改:update
删除:delete
4.1.插入语句
语法:
insert into 表名 (列名1,列名2,...) values (值1,值2,...), (值1,值2,...)...
不可以为NULL的列必须插入值,可以为NULL的值要想插入NULL值,必须在values里写NULL
也可以在字段列表里不写该字段,当新增时该字段的值就为NULL
列的顺序时可以随便调换的,列数和值的个数必须一致
插入整条数据时可以省去列名
insert into 表名 values (值1,值2...), (值1,值2...)...
values里面必须要插入所有字段的值,并且要按照字段的排列顺序排列
可以嵌套子查询:
insert into 表名 (值1,值2...) 子查询语句
还有第二种方法可以插入数据,语法如下:
insert into 表名
set 字段名1 = 字段值1, 字段名2 = 字段值2, 字段名3 = 字段值3, ...;
两种方法对比:
| 插入多行 | 子查询 | |
|---|---|---|
| value | √ | √ |
| set | X | X |
4.2.修改语句
语法:
修改单表的记录
update 表名 set 列1=值1, 列2=值2, ... where 筛选条件;
修改单表记录
sql92语法:
update 表1 别名, 表2 别名
set 列1=值1, 列2=值2, ...
where 连接条件
AND 筛选条件
sql99语法:
update 表1 别名
inner|right|left join 表2 别名
on 连接条件
set 列1=值1, 列2=值2, ...
where 筛选条件
4.3.删除语句
语法
单表删除:
delete from 表名 where 筛选条件;
删除整张表
truncate table 表名;
多表删除:
sql92语法
delete
delete 要删除表的别名
from 表1 别名, 表二 别名 ......
where 连接条件
and 筛选条件
sql99语法
delete 要删除表的别名
from 表1 别名
连接方式 表二 别名
...
where 筛选条件;
delete和truncate对比
| 使用where | 效率 | 自增 | 返回值 | 事务 | |
|---|---|---|---|---|---|
| delete | √ | 比truncate低 | 从断点点开始 | 返回受影响的行数 | 可以回滚 |
| truncate | X | 比delete高 | 从头开始 | 没有返回值 | 不能回滚 |
5.DDL(数据定义语言)
库和表的管理和操作
创建:create
删除:drop
修改:alter
5.1.库的管理
5.1.1.创建
语法:
create database (if not exists) 库名;
if not exists是如果不存在才创建
通用写法:
drop database if exists 库名;
create database 库名;
5.1.2.修改
更改库的字符集
alter database 库名 character set 字符集名;
5.1.3.删除
drop database 库名;
5.2.表的管理
5.2.1.创建
语法:
create table 表名{
列名 列的类型(长度) (约束),
列名 列的类型(长度) (约束),
列名 列的类型(长度) (约束),
...
列名 列的类型(长度) (约束)
}
通用写法:
drop table if exists 表名;
create table 表名{
列名 列的类型(长度) (约束),
列名 列的类型(长度) (约束),
列名 列的类型(长度) (约束),
...
列名 列的类型(长度) (约束)
}
5.2.2.修改
修改列名:
alter table 表名 change (column) 旧列名 新列名 列的类型;
修改列的类型或约束:
alter table 表名 modify column 列名 新类型 约束;
添加新列
alter table 表名 add column 新列名 列的类型 约束;
删除列
alter table 表名 drop column 列名;
修改表名
alter table 表名 rename to 新表名;
5.2.3.删除
语法:
drop table (if exists)表名;
5.2.4.复制
仅仅复制表的结构
create table 新表名 like 要复制的表名
复制表的结构+数据
create table 新表名
select 要复制的字段 from 要复制的表名
(where 筛选条件);
仅仅复制表的部分结构
create table 新表名
select 要复制的字段 from 要复制的表名
where 恒不成立的筛选条件 (例如 11 = 2 或者 0);
MySql学习笔记三的更多相关文章
- MYSQL学习笔记三:日期和时间函数
MYSQL学习笔记三:日期和时间函数 1. 获取当前日期的函数和获取当前时间的函数 /*获取当前日期的函数和获取当前时间的函数.将日期以'YYYY-MM-DD'或者'YYYYMMDD'格式返回 */ ...
- mysql学习笔记三 —— 数据恢复与备份
要点: 1.存储引擎2.导入导出3.备份与恢复 查看当前数据库中的所有表use db1:show tables: 1.存储引擎 不同的发动机(引擎)适用的汽车类型不一样. 存储和处理的不同方式.不同的 ...
- MySQL学习笔记三:库和表的管理
1.MySQL数据库服务配置好后,系统会有4个默认的数据库. information_schema:虚拟对象,其对象都保存在内存中 performance_schema:服务器性能指标库 mysql: ...
- mysql基本数据类型(mysql学习笔记三)
Mysql数据类型 小数: 浮点:小数位可以变化 Float单精度默认精度6位左右 Double 双精度默认精度16位左右 支持,控制数值范围 Type(M,D) M表示所有数值位数(不包括小数点和符 ...
- MySQL学习笔记(三)—索引
一.概述 1.基本概念 在大型数据库中,一张表中要容纳几万.几十万,甚至几百万的的数据,而当这些表与其他表连接后,所得到的新的数据数目更是要大大超出原来的表.当用户检索这么大量的数据时,经 ...
- MySQL学习笔记(三):常用函数
一:字符串函数 需要注意的几个细节: 1.cancat中有一个字符串为null,则结果为null. 2.left(str,x) 和 right(str,x)中x为null,则不返回任何字符串,不是nu ...
- mysql学习笔记(三)
-- 主键冲突(duplicate key) ,'xujian','anhui'); ,'xiewei','anhui'); ,'luyang','anhui');-- 主键冲突了 -- 可以选择性的 ...
- MySql学习笔记(三) —— 聚集函数的使用
1.AVG() 求平均数 select avg(prod_price) as avg_price from products; --返回商品价格的平均值 ; --返回生产商id为1003的商品价格平均 ...
- Mysql学习笔记(三)对表数据的增删改查。
正文内容. 这一部分是最简单的,也是最麻烦的.简单是因为其实只包括增删该插四个部分.大体上看,增加数据.删除数据.修改数据.查询数据都不麻烦啊,我们日常都是常用的.这个谁不会呢?以前在培训机构学mys ...
随机推荐
- python爬虫(2)——urllib、get和post请求、异常处理、浏览器伪装
urllib基础 urlretrieve() urlretrieve(网址,本地文件存储地址) 直接下载网页到本地 import urllib.request #urlretrieve(网址,本地文件 ...
- 高频Python面试题分享
一.Python语言中你用过哪些方式来实现进程间通信1.队列Queue 2.Pipe管道 只适用于两个进程之间的通信, pipe的效率高于queue 3.共享内存 4.socket套接字(UDP即可) ...
- linux shell攻略学习笔记一 基础篇
1.#!/bin/bash shebang 可以自定义 比如 #!/bin/bash +x 就会打印出执行日志 linux中 \ 代表null \n2\n3” 会转义其中的\n,生成3行数据 $! 保 ...
- Educational Codeforces Round 78 (Rated for Div. 2) 题解
Shuffle Hashing A and B Berry Jam Segment Tree Tests for problem D Cards Shuffle Hashing \[ Time Lim ...
- appium--python启动appium服务
前戏 前面我们都是在cmd下通过输入appium加端口号来启动服务的,在我们做自动化的时候,我们当然不希望我们手动启动appium服务,而是希望通过脚本自动启动appium服务. 我们可以使用subp ...
- 【转】UML各种图总结
UML(Unified Modeling Language)是一种统一建模语言,为面向对象开发系统的产品进行说明.可视化.和编制文档的一种标准语言.下面将对UML的九种图+包图的基本概念进行介绍以及各 ...
- MySQL实战45讲学习笔记:第三十七讲
一.本节概况 今天是大年初二,在开始我们今天的学习之前,我要先和你道一声春节快乐! 在第 16和第 34篇文章中,我分别和你介绍了 sort buffer.内存临时表和 join buffer.这三个 ...
- Paper | D3: Deep Dual-Domain Based Fast Restoration of JPEG-Compressed Images
目录 摘要 读后感 故事 深度双域法(D3) 发表于2016年CVPR. 摘要 既利用了CNN,又考虑了JPEG压缩的特性,解决JPEG图像去失真问题. 针对于压缩特性,作者考虑了JPEG压缩方案的先 ...
- vscode配置编译运行调试C/C++文件-windows环境
在windows环境下,编译运行小文件的C/C++环境 软件准备: vscode mingw64(官网下特别慢,可以在devc++安装软件里中找,放到全局变量中) 插件下载: Run Code C/C ...
- vuex 源码解析(四) mutation 详解
mutation是更改Vuex的store中的状态的唯一方法,mutation类似于事件注册,每个mutation都可以带两个参数,如下: state ;当前命名空间对应的state payload ...