【MySQL】SQL介绍+基础+DDL+数据备份+还原

目录

一、DDL建库建表

1. 数据库

2. 内部4特征

3. 外部4特征

4. 数据库结构

5. SQL语句分类(重点)

6. 注意

7. 数据库表的字段类型

8. 存储引擎

9. 数据库表的操作

二、三范式

1. 什么是范式

2. 约束作用

3. 三范式

4. 第一范式(1NF)确保每列保持原子性

5. 第二范式(2NF)属性完全依赖于主键

6. 第三范式(3NF)属性不依赖于其它非主属性 属性直接依赖于主键

三、表约束

1. 什么是约束

2. 约束作用

3. 约束种类

6.1 主键约束与“not null unique”区别

6.2 一般主键的建立方式

7. 外键约束

8. 约束的添加

9. 约束的删除

四、数据备份与还原

1. 使用工具

2. 控制台


一、DDL建库建表

1. 数据库

        概念:长期存放在计算机内,有组织、可共享的大量数据的集合,是一个 数据“仓库”。

        (1)作用:存放、管理数据

        (2)分类:关系型数据库、NoSQL数据库

                关系型数据库: MySQL、orcale、postgreSQl

                NoSQL数据库(非关系型数据库): redis、mongoDB

        (3)MySQL特点

                操作便捷

                小巧,功能齐全

                免费、开源的数据库

                可运行于windows或linux系统

2. 内部4特征

(1)数据的保存

(2)数据的完整性

(3)数据的读取

(4)数据的安全性

3. 外部4特征

(1)结构化

(2)共享性

(3)独立性

(4)安全性

4. 数据库结构

(1)数据库(Database)

        以文件的形式存放在磁盘上,即对应于一个或多个物理文件。

(2)数据表(Table)

        简称表,由一组数据记录组成,数据库中的数据是以表为单位进行组织的。一个表是一组相关的按行排列的数据;每个表中都含有相同类型的信息。

(3)字段(Field)

        也称域。表中的每一列称为一个字段。每个字段都有相应的描述信息。

(4)记录(Record)

        表中的每一行称为一个记录,它由若干个字段组成。实体

(5)索引(Index)

        索引实际上是一种特殊类型的表,其中含有关键字段的值和指向实际记录位置的指针,可以提高访问数据库的效率。

(6)SQL语句

        结构化查询语句命令,用来从一个或多个表中获取一组指定的记录,或者对某个表执行指定的操作。

5. SQL语句分类(重点)

(1)DDL(数据定义语言)   CREATE、DROP、ALTER

(2)DML(数据操作语言)   INSERT、UPDATE、DELETE

(3)DQL(数据查询语言)   SELECT

(4)DCL(数据控制语言)   GRANT、COMMIT、ROLLBACK

6. 注意

  1. # 注释
  2. -- 注释
  3. /*

                多行注释

        */

(1)sql不区分大小写

(2)_(下划线)进行名字的分割,不适用驼峰命名法

(3);语句sql结尾处写一个;来表示结束

(4)一般关键词建议用大写

(5)所有名称不允许使用中文

7. 数据库表的字段类型

(1)字符串类型

char和varchar区别(重点)

        都是字符串

  char(字符串长度)     固定长度字符串

  varchar(字符串长度)   可变长度字符串

  char(5)   'abcdef' 存不下      'abc  '不够补空格  可能浪费空间

  varchar(5)    'abcdef'   存不下       'abc'

  deimal(m,d)  m总长度   n小数位数

例:0-100,小数1位    deimal(4,1)  100三位+小数1位

(2)数值类型

(3)日期和事件类型

        null是一种类型,本身没值,表示空无一物

8. 存储引擎

        查看当前数据库支持的存储引擎:show engines;

(1)数据库存储引擎-InnoDB

        InnoDB是MysQL的默认事务型引擎,它被设计用来处理大量的短期(short-lived)事务。可以确保事务的完整提交(Commit)和回滚(Rollback)

        除了增加和查询外,还需要更新、删除操作,那么,应优先选择InnoDB存储引擎。

        除非有非常特别的原因需要使用其他的存储引擎,否则应该优先考虑InnoDB引擎。

        数据文件结构:

                • 表名.frm存储表结构(MySQL8.0时,合并在表名.ibd中)。

                • 表名.ibd存储数据和索引

        InnoDB是为处理巨大数据量的最大性能设计。

        对比MylISAM的存储引擎,InnoDB写的处理效率差一些,并且会占用更多的磁盘空间以保存数据和索引。

        MyISAM只缓存索引,不缓存真实数据;InnoDB不仅缓存索引还要缓存真实数据,对内存要求较高,而且内存大小对性能有决定性的影响。

(2)数据库存储引擎-MyISAM

        MyISAM提供了大量的特性,包括全文索引、压缩、空间函数(GIS)等,但MyISAM不支持事务、行级锁、外键,有一个毫无疑问的缺陷就是崩溃后无法安全恢复。

        优势是访问的速度快,对事务完整性没有要求或者以SELECT、INSERT为主的应用,MyISAM查询快,对增删改不友好

        针对数据统计有额外的常数存储。故而count(*)的查询效率很高

        数据文件结构:

                • 表名.frm存储表结构。

                • 表名.MYD存储数据(MYData)。

                • 表名.MYI存储索引 (MYIndex)

        应用场景:只读应用或者以读为主的业务

(3)数据库存储引擎-MyISAM 和InnoDB区别(重点)

9. 数据库表的操作

(1)创建表

        create table 表名(

                字段名 类型 属性,

                字段名 类型 属性,

                ...

                字段名 类型 属性

        );

(2)查看表结构

        方式一:desc 表名

        方式二:show create table 表名;

        `反引号 -- 取消关键性

        DEFAULT NULL 该字段的值可以为空

        DEFAULT CHARSET=utf8mb4      字符集

        COLLATE-utf8mb4_0900_ai_ci   字符排序

        ENGINE=InnoDB  非常重要  存储引擎  规则(InnoDB)

(3)表结构修改

        alter table 表名 关键词 数据;

        关键词:rename as、add、drop、modify、change。

        修改表名alter table 旧表名 rename as 新表名;

        添加字段(重点):alter table 表名 add 新字段名 类型 属性;

                alter table xuesheng add stu_qq varchar(20) comment '这是学生的qq号';

        comment相当于备注

(4)删除字段(危险操作)

        alter table 表名 drop 字段名;

(5)修改字段

        覆盖式

  • 一定的默认值
  • 如果有已经存在具体数据,数据是可以做隐式转换

方式一:modify 只能修改数据类型属性

        alter table 表名 modify 字段名 要修改的类型 要修改的属性;

方式二:change

        alter table 表名 change 旧字段名 新字段名 要修改类型 要修改属性

(6)删除表(危险操作)

        drop table [if exists] 表名

二、三范式

1. 什么是范式

        为了建立冗余较小、结构合理的数据库,设计数据库时必须遵循一定的规则。

        在关系型数据库中这种规则就叫做范式。

2. 约束作用

        数据库的设计范式是数据库设计所需要满足的规范,满足这些规范的数据库是简洁的、结构明晰的,同时,不会发生插入(insert)、删除(delete)和更新(update)操作异常。

3. 三范式

        第一范式:确保每列保持原子性

        第二范式:确保表中的每列都和主键相关

        第三范式:确保每列都和主键列直接相关,而不是间接相关

        第一范式 (拆字段):原子性(不可再分),拆到不可再拆为止,减少冗余和歧义

        第二范式(拆表):在第一范式基础上建立 ,数据库表中的每个实例或行必须可以被惟一地区分,主键(标识数据),属性完全依赖于主键。

        第三范式(拆表):每个属性都跟主键有直接关系而不是间接关系。

4. 第一范式(1NF)确保每列保持原子性

(1)每一列属性都是不可再分的属性值,确保每一列的原子性。

(2)两列的属性相近或相似或一样,尽量合并属性一样的列,确保不产生冗余数据。

5. 第二范式(2NF)属性完全依赖于主键

(1)第二范式(2NF)是在第一范式(1NF)的基础上建立起来的。即满足第二范式必须先满足第一范式。

(2)第二范式(2NF)要求数据库表中的每个实例或行必须可以被惟一地区分。为实现区分通常需要为表加上一个列,以存储各个实例的惟一标识。这个惟一属性列被称为主键。

6. 第三范式(3NF)属性不依赖于其它非主属性 属性直接依赖于主键

        数据不能存在传递关系,即每个属性都跟主键有直接关系而不是间接关系。

        像:a-->b-->c 属性之间含有这样的关系,是不符合第三范式的。

        比如Student表(学号,姓名,年龄,性别,所在院校,院校地址,院校电话)这样一个表结构,就存在上述关系。 学号--> 所在院校 --> (院校地址,院校电话)这样的表结构,我们应该拆开来,如下。

        (学号,姓名,年龄,性别,所在院校)--(所在院校,院校地址,院校电话)

        总结:三大范式只是一般设计数据库的基本理念,可以建立冗余较小、结构合理的数据库。如果有特殊情况,当然要特殊对待,数据库设计最重要的是看需求跟性能,需求>性能>表结构。所以不能一味的去追求范式建立数据库。

三、表约束

1. 什么是约束

        约束实际上就是表中数据的限制条件。

2. 约束作用

        表在设计的时候加入约束的目的就是为了保证表中的记录完整和有效。

3. 约束种类

  • 非空约束(not null)
  • 唯一性约束(unique)
  • 主键约束(primary key) PK
  • 外键约束(foreign key) FK
  • 检查约束(目前MySQL不支持、Oracle支持)

4.非空约束

        用not null约束的字段不能为null值,必须给定具体的数据

        create table tb2(

        username varchar(10) not null, -- 非空约束

        userage int

        );

        create table tb3(

           username varchar(10) not null default '无名', -- 非空约束

           userage int

        );

5. 唯一约束

        是可以为null,并且可以有多个null,因为null是一个类型。

create table tb4(

   username varchar(10) unique, -- 唯一约束,行级约束,只约束一个字段

   userage int unique           -- 每个字段都是各自的唯一约束

);

create table tb5(

   username varchar(10),

   userage int,      

   unique(username,userage)   -- 表级约束 / 联合唯一约束  

                             -- 字段是有关联的,必须每个字段的值都相同才会触发唯一约束(两条记录username,userage完全一样时,数据无法存取)

);

6. 主键约束

        主键(primary key)是表中的一个或多个字段,它的值用于唯一的标识表中的某一条记录。

  • 每张表必须有且只有一个主键
  • 主键的只是唯一的
  • 主键是不能为null
  • 用来做标识
  • 一张表应该有主键字段,如果没有,表示该表无效
6.1 主键约束与“not null unique”区别

(1)作为Primary Key的域/域组不能为null,而Unique Key可以。

(2)在一个表中只能有一个Primary Key,而多个Unique Key可以同时存在。unique not null 可以将表的一列或多列定义为唯一性属性,而primary key设为多列时,仅能保证多列之和是唯一的,具体到某一列可能会重复。

(3)更大的区别在逻辑设计上。Primary Key一般在逻辑设计中用作记录标识,这也是设置Primary Key的本来用意,而Unique Key只是为了保证域/域组的唯一性。

create table tb7(

   username varchar(10) primary key,

   userage int primary key    -- 错误

);

create table tb8(

   username varchar(10),

   userage int,

   primary key(username,userage)  -- 联合主键 / 联合约束

                                  -- 多个字段完全相同时,才会触发

);

6.2 一般主键的建立方式
  • int bitint 自增
  • 主键的值不会回补

create table tb9(

   tid int primary key auto_increment,  -- 自增

   username varchar(10),

   userage int

);

7. 外键约束

        外键用于与另一张表的关联。是能确定另一张表记录的字段,用于保持数据的一致性。

        若有两个表A、B,id是A的主键,而B中也有id字段,则id就是表B的外键 。A为基本表或父表,主表,B为信息表,子表,副表

        只能是表级定义。

        foreign key(表的字段名) references 父表表名(父表的字段名)

按外键约束的字段数量分类:

        单一外键:给一个字段添加外键约束

        复合外键:给多个字段联合添加一个外键约束

  • 外键的值可以重复
  • 外键的值可以为null
  • 外键必须要写父表中有的数据
  • 父表中的关联字段必须是一个具有唯一性的数据
  • 父表的字段名和从表的字段名不一定要相同,但是数据类型必须一致
  • 一个表中可以有多个外键,也可以有多个外键约束,但是只能有一个主键
  • 外键约束和外键关系 不一样, 关系没有形成约束
  • 先添加父表数据,再添加子表数据
  • 先删子表数据,再删父表数据
  • 使用外键关系,不去建立外键约束

create table a(

   aid int primary key auto_increment,

   aname varchar(10)

);

create table b(

   bid int primary key auto_increment,

   bname varchar(10),

   aid int,

   foreign key(aid) references a(aid)

);

8. 约束的添加

        添加非空约束

                alter table 表名 modify test_student char(10) not null;

        添加唯一约束

                alter table 表名 add unique(表字段名,字段,字段,字段);

        添加主键约束

                alter table 表名 add primary key(表的字段名,字段,字段);

        添加外键约束

                alter table 表名 add constraint N1 foreign key (表字段名) references 父表(父表字段名);

9. 约束的删除

        删除not null约束

                alter table 表名 modify 列名 类型;

        删除unique约束

                alter table 表名 drop index 唯一约束名;

        删除primary key约束

                alter table 表名 drop primary key;

        删除foreign key约束

                alter table 表名 drop foreign key 外键名;

四、数据备份与还原

1. 使用工具

2. 控制台

        在F:\MySQL\MySQL Server 5.7\bin        -- cmd中(终端)

(1)数据备份

        mysqldump.exe -h localhost -P 3306 -u root -p xiaozhao2 > F:/Task/myschool.sql

        passward

        -h 服务器     -P端口号

        > 尖尖对应目标

        < 开口对应数据

(2)数据还原

        导入linux中数据库

        阿里云mysql先建库

        mysql.exe -h 121.41.85.102 -P 3306 -u root -p haha < F:/Task/myschool.sql       

        passward

        121.41.85.102为shell 主机ip

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/55337.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Android 14源码分析】Activity启动流程-2

忽然有一天&#xff0c;我想要做一件事&#xff1a;去代码中去验证那些曾经被“灌输”的理论。                                                                                  – 服装…

Visual Studio C# 编写加密火星坐标转换

Visual Studio C# 编写加密火星坐标转换 1、WGS84坐标转GCJ02火星坐标2、GCJ02火星坐标转WGS84坐标&#xff08;回归计算&#xff09;3、GCJ02火星坐标转BD09百度坐标4、BD09百度坐标转GCJ02火星坐标&#xff08;回归计算&#xff09;5、坐标公共转换类6、地图显示7、程序简单界…

检查jar冲突,查找存在相同class的jar

写在前面 本文看下如何查找jar冲突&#xff0c;即查找哪些jar包中存在相同的class。如果是存在相同jar的不同版本&#xff0c;基本一眼就能看出来&#xff0c;然后结合maven的依赖关系将其剔除掉即可&#xff0c;但是当你遇到了有人手动拷贝某些class到jar包中导致冲突的情况时…

【AI知识点】维度灾难(curse of dimensionality)

维度灾难&#xff08;curse of dimensionality&#xff09; 是指在处理高维数据时&#xff0c;随着维度的增加&#xff0c;数据的性质和空间结构变得越来越复杂&#xff0c;导致许多常见的算法和技术在高维空间中效率低下或效果变差的问题。 这个概念最早是由Richard Bellman在…

OpenCAEPoro安装与测试(ASC 2024)

首先简单总结一下经验&#xff1a; 在之前的测试和学习中&#xff0c;由于自己是虚拟机或者云服务器&#xff0c;有root权限&#xff0c;经常无脑增删文件&#xff08;主要是为了图省事&#xff0c;看见报错就加回来&#xff0c;多出来就删除&#xff09;&#xff0c;但是在经…

Ubuntu Server 20.04 64bit定时备份MySQL8.0.36数据库数据

一、编写sh脚本 常见备份命令介绍 我选用的是mysqldump命令&#xff0c;命令使用简介 [root]> mysqldump -helpUsage: mysqldump [OPTIONS] database_name [tables] OR mysqldump [OPTIONS] --databases [OPTIONS] DB1 [DB2 DB3...] OR mysqldump [OPTIONS] --all…

python全栈学习记录(二十一)类的继承、派生、组合

类的继承、派生、组合 文章目录 类的继承、派生、组合一、类的继承二、派生三、组合 一、类的继承 继承是一种新建类的方式&#xff0c;新建的类称为子类&#xff0c;被继承的类称为父类。 继承的特性是&#xff1a;子类会遗传父类的属性&#xff08;继承是类与类之间的关系&a…

程序猿成长之路之设计模式篇——设计模式简介

无论是对于代码质量还是代码可维护性、可扩展性&#xff0c;使用合适的设计模式都能够起到促进提升的作用&#xff0c;此外在软考的软件工程师、系统架构师职称考试中&#xff0c;设计模式也是必考的一块内容&#xff0c;因此我打算开拓一个新的专栏简单介绍一下设计模式&#…

腾讯一面-LRU缓存

为了设计一个满足LRU&#xff08;最近最少使用&#xff09;缓存约束的数据结构&#xff0c;我们可以使用哈希表&#xff08;HashMap&#xff09;来存储键值对&#xff0c;以便在O(1)时间复杂度内访问任意键。同时&#xff0c;我们还需要一个双向链表&#xff08;Doubly Linked …

智慧水务可视化:高效管理水资源

利用图扑先进的可视化技术&#xff0c;实现对水资源的实时监控与高效管理&#xff0c;提高水务工作的透明度和决策效率&#xff0c;促进水资源的可持续利用。

太原网站制作打造企业网站的关键要素

太原网站制作&#xff1a;打造企业网站的关键要素 在数字化时代&#xff0c;企业网站成为了品牌形象和市场营销的重要一环。太原的企业在进行网站制作时&#xff0c;需要关注几个关键要素&#xff0c;以确保网站能够有效提升企业竞争力和用户体验。 **1. 目标明确** 在网站制…

利用Spring Boot打造新闻推荐解决方案

1系统概述 1.1 研究背景 如今互联网高速发展&#xff0c;网络遍布全球&#xff0c;通过互联网发布的消息能快而方便的传播到世界每个角落&#xff0c;并且互联网上能传播的信息也很广&#xff0c;比如文字、图片、声音、视频等。从而&#xff0c;这种种好处使得互联网成了信息传…

Elasticsearch 8.16 和 JDK 23 中的语言环境变化

作者&#xff1a;来自 Elastic Simon Cooper 随着 JDK 23 即将发布&#xff0c;语言环境信息中有一些重大变化&#xff0c;这将影响 Elasticsearch 以及你提取和格式化日期时间数据的方式。首先&#xff0c;介绍一些背景知识。 什么是语言环境&#xff1f; 每次 Java 程序需要…

资源《Arduino 扩展板4-单游戏摇杆》说明。

资源链接&#xff1a; Arduino 扩展板4-单游戏摇杆 1.文件明细&#xff1a; 2.文件内容说明 包含&#xff1a;AD工程、原理图、PCB。 3.内容展示 4.简述 该文件为PCB工程&#xff0c;采用AD做的。 该文件打板后配合Arduino使用&#xff0c;属于Arduino的扩展板。 该文件…

JVM和GC监控技术

一、监控技术简介 JVM是什么&#xff1f;项目里面有JVM吗&#xff1f;JVM跟Tomcat有什么关系&#xff1f;为什么需要去分析JVM&#xff1f; 1. JVM(全称&#xff1a;Java Virtual Machine)&#xff0c;Java虚拟机 是Java程序运行的环境&#xff0c;它是一个虚构的计算机&…

Netty 与 WebSocket之间的关系

WebSocketProtocolHandler 和 Netty 在处理 WebSocket 连接时扮演不同的角色&#xff0c;但它们通常是一起使用的&#xff0c;尤其是在基于 Netty 的项目中。为了更好地理解它们之间的区别&#xff0c;我们首先需要了解 WebSocket 和 Netty 的基本概念。 WebSocket WebSocket…

RK3568平台(显示篇)车机图像显示偏白问题分析

一.显示偏白图片对比 正常图像: 偏白图像: 二.分析过程

51单片机系列-按键检测原理

&#x1f308;个人主页&#xff1a;羽晨同学 &#x1f4ab;个人格言:“成为自己未来的主人~” 独立按键是检测低电平的。 下面我们来看一张对应的电路原理图&#xff1a; 在这张图当中&#xff0c;P1&#xff0c;P2&#xff0c;P3内部都上拉了电阻&#xff0c;但是P0没有&am…

day03 笔试练习

1.简写单词 题目链接&#xff1a;简写单词_牛客题霸_牛客网 public static void main(String[] args) {Scanner sc new Scanner(System.in);while(sc.hasNext()){ // 输入多少读入多少char ch sc.next().charAt(0); // 提取首字母if(ch > a && ch < z){System…

项目定位与服务器(SERVER)模块划分

目录 定位 HTTP协议以及HTTP服务器 高并发服务器 单Reactor单线程 单Reactor多线程 多Reactor多线程 模块划分 SERVER模块划分 Buffer 模块 Socket模块 Channel 模块 Connection模块 Acceptor模块 TimerQueue模块 Poller模块 EventLoop模块 TcpServer模块 SE…