MySQL day1

day01

今日内容

  • 数据类型和约束
  • 通过SQL语句实现一系列操作
    • 对数据库的操作
    • 对数据表的操作
    • 对数据的操作

数据类型和约束

为了更加准确的存储数据,保证数据的有效性,需要合理的使用数据类型和约束来限制数据的存储

  • 整数:int,有符号范围(-2147483648-2147483647),无符号(0-4294967295)
  • 小数:decimal,例如:decimal(5,2)表示共存5位数,小数占2位,整数占3位
  • 字符串:varchar,范围(0-65533),例如:varchar(3)表示最多存3个字符,一个中文或一个字母都占一个字符
  • 日期时间:datetime,范围(1000-01-01 00:00:00 ~ 9999-12-31
    23:59:59),例例如:'2020-01-
    01 12:29:59'

整数⽆无符号设置


约束

约束: 对于整张数据表进⾏行行限制, 确保对应字段的所有数据符合设计要求

  • 主键(primary key): 能唯⼀标识表中的每⼀条记录的属性组
  • ⾮空(not null): 此字段不不允许填写空值
  • 唯⼀(unique): 此字段的值不不允许重复
  • 默认值(default): 当不不填写此值时会使⽤用默认值,如果填写时以填写为准
  • 外键(foreign key): ⼀个表中的一个字段引⽤用另⼀个表的主键

主键

不为空

唯⼀

索引 -> 字段

选择索引类型为: unique(唯⼀)

默认值


SQL 语句句

查询窗⼝口的开启⽅方法


单语句运⾏⽅法

数据库操作

  • 创建数据库
  • 使用数据库
  • 修改数据库
  • 删除数据库

创建数据库

# 创建数据库
# create database 数据库名 charset=utf8 collate=utf8_general_ci; 
create database python charset=utf8 collate=utf8_general_ci;
# 查看数据库
# show create database 数据库名; 
show create database python;

使⽤用数据库

# 使⽤用数据库(切换数据库) 
# use 数据库名;
use python;
# 查看当前数据库: database() 是 SQL 的内置函数, 括号不不能省略略! 
select database();

修改数据库

# 修改数据库 
# 创建
create database testpython charset = gb2312; 
# 修改
# alter database 数据库名
# default character set 编码格式 
# default collate 排序规则;
alter database testpython
default character set utf8mb4 
default collate utf8mb4_general_ci;

删除数据库和查看所有数据库

# 删除数据库
# drop database 数据库名; 
drop database python;
# 查看所有数据库 
show databases;

重点: 数据库备份

应用场景

说明: 在测试工作中, 为了防止对数据库产生错误操作, 或产生垃圾数据, 都需要在操作前, 适当对数据库进⾏备份操作.
垃圾数据: 例如在自动化测试中, 对注册模块操作生成的所有数据, 属于典型的垃圾数据, 应该清理

备份方法
利⽤⼯具

备份步骤

数据库 -> 转储 SQL ⽂文件 -> 结构+数据

⾃⾏选择存放位置

备份结束

还原操作

数据库 -> 运⾏SQL 文件

选择备份⽂件

还原结束

扩展: 使⽤命令备份

注意: 命令是不需要连接到数据库以后执⾏行的!(⾮ mysql> 模式)
mysql> 为 SQL 语句编写模式, 非 Linux 命令⾏模式

命令备份与还原数据库操作

数据表操作

创建表

数据表操作 
创建表
# 创建表
# create table 表名( 
# 字段名    类型    约束, 
# 字段名    类型    约束
# ...
# )
# 简单创建 
create table stu(
  name varchar(5)
);
# 完整创建
# unsigned : ⽆符号
# primary key : 主键
# auto_increment : 自动增⻓ 
create table students(
  id int unsigned primary key auto_increment, 
  name varchar(20),
  age int unsigned, 
  height decimal(5,2)
);

查看表

# 查看表信息
# show create table 表名; 
show create table students;
# 执⾏行行结果
# CREATE TABLE `students` (
#   `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
#   `name` varchar(20) DEFAULT NULL,
#   `age` int(10) unsigned DEFAULT NULL,
#   `height` decimal(5,2) DEFAULT NULL,
#   PRIMARY KEY (`id`)
# ) ENGINE=InnoDB DEFAULT CHARSET=utf8

扩展: 判断表存在移除再创建

# 扩展: 判断表是否存在, 存在时先删除再创建 
# drop table : 删除表
# if exists students : 如果 students 存在 
drop table if exists students;
create table students(
  id int unsigned primary key auto_increment, 
  name varchar(20),
  age int unsigned, 
  height decimal(5,2)
);

扩展: 通过 Navicat 工具获取创表语句的方法

windows上表鼠标右键选择对象信息,选择DDL就能看见

查看表结构和删除表

# 查看表结构(字段) 
# desc 表名; 
desc students;
# 删除表
# drop table 表名; 
drop table students;

数据操作

增加数据

增加⼀行数据
-- 增加数据 
-- 增加⼀行数据
-- insert into 表名 values(...) 
-- 注意:
-- 1. 数据值需要和表的字段⼀一对应(数据个数及数据类型)
-- 2. 主键列是自动增长,插入时需要占位,通常使用 0 或者 default 或者 null 来占位,插入成功后以实际数据为准
insert into students values(0, '张三', 28, 1.78); 
-- 增加部分值
-- insert into 表名(字段1,...) values(值1,...) 
-- 注意: 值的顺序与给出的字段顺序对应
insert into students(name, height) values('李李四', 1.68);
增加多⾏行行数据
-- 插⼊多行数据
-- ⽅式1: 将单行插入语句, 多句执⾏, 每句分号隔开
insert into students values(0, '王五', 28, 1.78);
insert into students(name, height) values('赵六', 1.68);
-- ⽅式2: 在插⼊单行数据的语法基础上, 将 value 后边的数据进行多组化处 理
-- insert into 表名 values(...),(...)...
-- insert into 表名(列列1,...) values(值1,...),(值1,...)... 
insert into students values(0, '王五1', 29, 1.78),(0, '王五2', 30, 1.78);
insert into students(name, height) values('赵六1', 1.78),('赵六 2', 1.88);
修改数据
-- 修改数据
-- update 表名 set 列列1=值1,列列2=值2... where 条件 
-- 注意: where 不不能省略略, 否则会修改整列列数据 
update students set age=48 where id=9;

语句作用对应

删除数据

-- 删除数据
-- delete from 表名 where 条件;
-- 注意: where 不不能省略略, 否则会删除全部数据 
delete from students where id=6;
扩展 1: 逻辑删除

逻辑删除: 对于重要的数据,不能轻易执⾏行 delete 语句进行删除。因为⼀旦删除,数据⽆法恢复,这时可以进行逻辑删除。
1、给表添加字段,代表数据是否删除,一般起名 isdelete,0代表未删除,1代表删除,默认值为0
2、当要删除某条数据时,只需要设置这条数据的 isdelete 字段为1
3、以后在查询数据时,只查询出 isdelete 为0的数据
第⼀步

第⼆和第三步

-- 扩展 1: 逻辑删除(假删/标记删除)
-- 1> 修改要删除的数据的特定字段为删除状态 
update students set isdelete=1 where id=4; 
-- 2> 查询所有 isdelete 字段为 0 的所有数据 
select * from students where isdelete=0;
扩展 2: 其他删除数据的⽅法
-- 扩展 2: 其他数据删除⽅方法
-- delete from 表名 : 删除所有数据, 但是不不重置主键字段的计数 
-- truncate table 表名 : 删除所有数据, 并重置主键字段的计数 
-- drop table 表名 : 删掉表(字段和数据均不不再存在)
delete from students; 
truncate table students; 
drop table students;

与图形化⻚面菜单的对应关系

今⽇任务

整理今⽇内容(思维导图/笔记) -> 将来可用为准[优先级最低]
预习数据查询内容!!!!!![优先级最高] -> 截止到分页查询

posted @ 2022-05-05 17:40  godbelongtome  阅读(19)  评论(0编辑  收藏  举报
Language: HTML Language: CSS /* 禁止页面,选中 复制 */ html,body { moz-user-select: -moz-none; -moz-user-select: none; -o-user-select: none; -khtml-user-select: none; -webkit-user-select: none; -ms-user-select: none; user-select: none; }