MySQL数据库之表的增删改查
MySQL数据库之表的增删改查
1 引言
1、MySQL数据库中,数据库database就是硬盘上的一个文件夹,表table就是文件夹里面的一个文件
2、表中的一条记录就相当于文件中的一行内容,与excel表类似,表table中有不同的标题,称之为字段
3、本节对表结构做增删改查,即创建表、删除表、修改表、查看表结构,至于表中数据的增删改查日后单独总结
2 创建表
1、创建一张表,需要建一个表结构,需要表名、表中字段的名字,字段的数据类型及约束条件等
#建表语法:
create table 表名(
字段1 数据类型[(宽度) 约束条件],
字段2 数据类型[(宽度) 约束条件],
字段3 数据类型[(宽度) 约束条件],
......) engine=innodb;
#注意:
1、一张表中字段名不能相同
2、字段的数据类型不能少、宽度和约束条件是可选的
3、搜索引擎默认engine=innodb,可默认不写
#示例:
#建一张学生表,包含学生id\姓名\年龄\性别\分数5个字段
create table student(
id int,
name char(10) not null, #约束条件,not null 不为空
sex char(10),
score int);
#注意:
1、每个字段用逗号隔开,最后一个字段不用逗号
2、int数据类型可以不指定宽度,日后再解释
3 删除表
1、不同的删除方式会有不同的效果,说白点就是有的删除方式删除的干净,而有的则不是
2、方式1的 drop,彻底删除表全部数据和表结构,立刻释放磁盘空间
3、方式2的 truncate,删除表全部数据,保留表结构,立刻释放磁盘空间
4、方式3的 delete from,删除表全部数据,表结构不变,对于 MyISAM 会立刻释放磁盘空间,InnoDB 不 会释放磁盘空间;这种删除后表中 auto_increment的字段会有影响,需注意!
#方式1:
drop table 表名;
#方式2:
truncate table 表名;
#方式3:
delete from 表名;
4 修改表
1、修改表指的是:修改表名、字段名及其约束条件,和删除字段等操作
2、修改字段时,需要指定数据类型,不管是否修改数据类型
3、增加字段、可以一次增加多个,用逗号隔开;也可以指定新字段的位置
#语法:
#1修改表名
alter table 表名 新表名;
#2修改字段约束条件
alter table 表名 modify 字段名 数据类型[(宽度) 约束条件];
#3修改字段名
alter table 表名 change 旧字段名 新字段名 旧数据类型[(宽度) 约束条件];
alter table 表名 change 旧字段名 新字段名 新数据类型[(宽度) 约束条件];
#4增加字段
alter table 表名 add 新字段名1 数据类型[(宽度) 约束条件],
新字段名2 数据类型[(宽度) 约束条件];
alter table 表名 add 新字段名 数据类型[(宽度) 约束条件] first;
alter table 表名 add 新字段名 数据类型[(宽度) 约束条件] after 字段名;
#5删除字段
alter table 表名 delete drop 字段名;
5 查看表
#语法:
desc 表名; #desc是describe的简写
注意:show create table t1\G; #查看表详细结构,可加\G
6 复制表
1、复制表分两种:完全复制(数据和结构),仅复制表结构
2、方式1的复制会复制原表的数据和结构,但key不会复制(primary key\unique key\索引)
3、方式2的复制是因为存在where 条件是Flase,过滤掉了多有数据,就仅剩表结构
4、推荐方式3的复制表结构
#1完全复制
create table 新表名 select * from student; #方式1
#2 仅复制表结构,
create table 新表名 select *from student where 1=2; #方式2
create table 新表名 like student; #方式3
MySQL数据库之表的增删改查的更多相关文章
- Mysql数据库和表的增删改查以及数据备份&恢复
数据库 查看所有数据库 show databases; 使用数据库 use 数据库名; 查看当前使用的数据库 select database(); 创建数据库 create database 数据库名 ...
- MySQL数据库 | 数据表的增删改查
MySQL数据的增删改查(crud) 本文结构 一.增加 create 二.修改 update 三.查询 retrieve(简单查询,下篇详细展开) 四.删除 delete 首先,创建简单的class ...
- MySQL数据库2表的增删改查
目录 一.数据表(文件): 1.1增 1.2查看表内数据 1.3改 1.4删除列表 1.5查看库内列表及表结构 1.6复制表结构 二.列类型:(*********) 2.1数字 2.2字符串 2.3时 ...
- Mysql数据库二:表的增删改查
----建表CREATE TABLE emp( id int PRIMARY key auto_increment, name char(10) , birthday DATE , salary FL ...
- MySQL数据库与表的增删改查
1.值库管理 1.1 查询所有值库 show databases; 1.2 创建一个值库 create database 值库名称 default character set 编码格式名称; 1.3 ...
- 使用JDBC分别利用Statement和PreparedStatement来对MySQL数据库进行简单的增删改查以及SQL注入的原理
一.MySQL数据库的下载及安装 https://www.mysql.com/ 点击DOWNLOADS,拉到页面底部,找到MySQL Community(GPL)Downloads,点击 选择下图中的 ...
- Python操作MySQL数据库完成简易的增删改查功能
说明:该篇博客是博主一字一码编写的,实属不易,请尊重原创,谢谢大家! 目录 一丶项目介绍 二丶效果展示 三丶数据准备 四丶代码实现 五丶完整代码 一丶项目介绍 1.叙述 博主闲暇之余花了10个小时写的 ...
- 在python中连接mysql数据库,并进行增删改查
数据库在开发过程中是最常见的,基本上在服务端的编程过程中都会使用到,mysql是较常见的一种数据库,这里介绍python如果连接到数据库中,并对数据库进行增删改查. 安装mysql的python扩展 ...
- python3.6 使用 pymysql 连接 Mysql 数据库及 简单的增删改查操作
1.通过 pip 安装 pymysql 进入 cmd 输入 pip install pymysql 回车等待安装完成: 安装完成后出现如图相关信息,表示安装成功. 2.测试连接 import ...
随机推荐
- Java EE.Servlet.生成响应
Servlet的核心职责就是根据客户端的请求生成动态响应. 1.编码类型 2.流操作(下载文件) servlet支持两种格式的输入/输出流.一种是字符输入输出流.另一种是字节输入输出流. 3.重定向
- <<Modern CMake>> 翻译 2. CMake 基础
<<Modern CMake>> 翻译 2. CMake 基础 最低版本 这是每个 CMakeLists.txt 文件的第一行.CMakeLists.txt 是 CMake 所 ...
- 分布式锁----Redis实现
分布式锁 为什么需要有分布式锁呢,在单点的时候synchronized 就能解决,但是服务拆分之后,每个服务都是单独的机器,无法解决,所以出现了分布式锁,其实也就是用各种手段,实现获取唯一锁,别人无法 ...
- Spring AOP 面向切面的Spring
定义AOP术语 描述切面的常用术语有: 通知 (advice) 切点 (pointcut) 连接点 (joinpoint) 下图展示了这些概念是如何关联的 Spring 对AOP的支持 Spring提 ...
- springboot整合elasticsearch(基于es7.2和官方high level client)
前言 最近写的一个个人项目(传送门:全终端云书签)中需要用到全文检索功能,目前 mysql,es 都可以做全文检索,mysql 胜在配置方便很快就能搞定上线(参考这里),不考虑上手难度,es 在全文检 ...
- Linux学习笔记05之网络基础知识
一.OSI参考模型:适用于所有网络,现有模型,后有协议 1.应用层:应用程序.用户接口 2.表示层:编码转换.压缩.解压.加密等 3.会话层:建立.维护.拆除会话 4.传输层规定了应用程序的的接口 协 ...
- 【iOS】Assertion failure in -[MASViewConstraint install]
刚遇到了这个问题,详细信息如下: Assertion failure 错误原因: 控件没有添加到视图就使用 mas_makeConstraints 了……应该先把控件添加到视图.
- HTML 第5章CSS3美化网页元素
<span>标签: <span>标签是用来组合HTML文档中的行内元素,它没有固定的格式表示. 字体样式: 属性名 ...
- hive数仓客户端界面工具
1.Hive的官网上介绍了三个可以在Windows中通过JDBC连接HiveServer2的图形界面工具,包括:SQuirrel SQL Client.Oracle SQL Developer以及Db ...
- go 学习笔记之走进Goland编辑器
工欲善其事必先利其器,命令行工具虽然能够在一定程度上满足基本操作的需求,但实际工作中总不能一直使用命令行工具进行编码操作吧? 学习 Go 语言同样如此,为此需要寻找一个强大的 IDE 集成环境帮助我们 ...