Python MySQL数据库1:数据存储介绍、阿里云安装myspl(使用)以及客户端 Navicat使用(下)

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: Python MySQL数据库1:数据存储介绍、阿里云安装myspl(使用)以及客户端Navicat使用(下)

八、通过navicat操作数据库


  • 8.1、在 7.3 里面,我们已经安装好 navicat,那么我们使用一下它。
  • 8.2、建库
  • 选中一个库,右击建库


image.png

选择 utf8 作为字符集


image.png

选择普通的默认排序


image.png

8.3、建表 和 在表中建字段


image.png


image.png


image.png

九、数据完整性



  • 9.1、一个数据库就是一个完整的业务单元,可以包含多张表,数据被存储在表中;在表中为了更加准确的存储数据,保证数据的正确有效,可以在创建表的时候,为表添加一些强制性的验证,包括数据字段的类型、约束。


  • 9.2、数据类型
  • 可以通过查看帮助文档查阅所有支持的数据类型
  • 使用数据类型的原则是:够用就行,尽量使用取值范围小的,而不用大的,这样可以更多的节省存储空间
  • 常用数据类型如下:
  • 整数:int,bit(更小的类型)
  • 小数:decimal
  • 字符串:varchar,char
  • 日期时间: date, time, datetime
  • 枚举类型(enum)
  • 特别说明的类型如下:
  • decimal表示浮点数,如decimal(5,2)表示共存5位数,小数占2位
  • char表示固定长度的字符串,如char(3),如果填充'ab'时会补一个空格为'ab '
  • varchar表示可变长度的字符串,如varchar(3),填充'ab'时就会存储'ab'
  • 字符串text表示存储大文本,当字符大于4000时推荐使用
  • 对于图片、音频、视频等文件,不存储在数据库中,而是上传到某个服务器上,然后在表中存储这个文件的保存路径(我一般他视频或者图片放到七牛云,在自己的服务器存储视频或者图片的链接)
  • 更全的数据类型可以参考:东哥推荐的博客


  • 9.3、约束


  • 主键primary key:物理上存储的顺序
  • 非空not null:此字段不允许填写空值
  • 惟一unique:此字段的值不允许重复
  • 默认default:当不填写此值时会使用默认值,如果填写时以填写为准
  • 外键foreign key:对关系字段进行约束,当为关系字段填写值时,会到关联的表中查询此值是否存在,如果存在则填写成功,如果不存在则填写失败并抛出异常;提示:在自己的表中导入的其他表的主键是外键
  • 说明:虽然外键约束可以保证数据的有效性,但是在进行数据的crud(增加、修改、删除、查询)时,都会降低数据库的性能,所以不推荐使用,那么数据的有效性怎么保证呢?答:可以在逻辑层进行控制;


  • 9.4、类型表
  • 数值类型(常用)


类型 字节大小 有符号范围(Signed) 无符号范围(Unsigned)
TINYINT 1 -128 ~ 127 0 ~ 255
SMALLINT 2 -32768 ~ 32767 0 ~ 65535
MEDIUMINT 3 -8388608 ~ 8388607 0 ~ 16777215
INT/INTEGER 4 -2147483648 ~2147483647 0 ~ 4294967295
BIGINT 8 -9223372036854775808 ~ 9223372036854775807 0 ~ 18446744073709551615
  • 字符串


类型 字节大小 示例
CHAR 0-255 类型:char(3) 输入 'ab', 实际存储为'ab ', 输入'abcd' 实际存储为 'abc'
VARCHAR 0-255 类型:varchar(3)'ab',实际存储为'ab', 输入'abcd',实际存储为'abc'
TEXT 0-65535 大文本
  • 日期时间类型


类型 字节大小 示例
DATE 4 '2020-01-01'
TIME 3 '12:29:59'
DATETIME 8 '2020-01-01 12:29:59'
YEAR 1 '2017'
TIMESTAMP 4 '1970-01-01 00:00:01' UTC ~ '2038-01-01 00:00:01' UTC


十、命令行脚本操作数据库



  • 10.1、链接数据库
  • 链接
  • 第一种:需要输入密码


mysql -uroot -p
输入密码进入
  • 第二种:直接跟上密码(-p与密码之间没有间隔)


mysql -u root -p密码
  • 链接成功


image.png

  • 退出登录


quit 和 exit 或 ctrl+d
  • 登录成功后,输入如下命令查看效果


查看版本:select version();
显示当前时间:select now();
  • 修改输入提示符


prompt python>
  • \D 完整日期
  • \U 使用用户


  • 10.2、数据库


  • 查看所有数据库


show databases;
  • 使用数据库


use 数据库名;
  • 查看当前使用的数据库


select database();
  • 创建数据库(查看创建方式:show create table classes;


create database 数据库名 charset=utf8;
  • 例如:testBase是数据库名字


create database testBase charset=utf8;
  • 删除数据库


drop database 数据库名;
  • 例如:testBase是上面创建的数据库名字
drop database testBase;
  • 10.3、数据表
  • 查看当前数据库中所有表


show tables;
  • 查看表结构


desc 表名;
  • 创建表,auto_increment 表示自动增长


CREATE TABLE table_name(
      column1 datatype contrai,
      column2 datatype,
      column3 datatype,
      .....
      columnN datatype,
     PRIMARY KEY(one or more columns)
);
  • 例:创建班级表


create table classes(
     id int unsigned auto_increment primary key not null,
     name varchar(10)
);
  • 例:创建学生表(primary key auto_increment not null:设为主键、自增长、不为空)  约束的顺序随便写,最后一个字段不要 逗号,在定义类型的时候,后面加上 unsigned 表示无符号,gender enum('男','女','人妖','保密') default "保密",可以为gender设置默认值 "保密"


create table students(
     id int unsigned primary key auto_increment not null,
     name varchar(20) default '',
     age tinyint unsigned default 0,
     height decimal(5,2),
     gender enum('男','女','人妖','保密') default "保密",
      cls_id int unsigned default 0
);


image.png

  • 给表添加数据


insert into students values(0,"马冶",26,172.33,"男",1)
查询表内容
select * from students;
  • 修改表-添加字段


alter table 表名 add 列名 类型;
  • 例如:给students表添加生日字段


alter table students add birthday datetime;


image.png

修改表-修改字段:重命名版(字段名字、类型、及约束 都可以改变)

alter table 表名 change 原名 新名 类型及约束;

例如:把学生的 birthday 改为 birth 类型还是datetime not null,不能为空

alter table students change birthday birth datetime not null;


image.png

修改表-修改字段:不重命名版(字段名字不变,类型以及约束可以改变)

alter table 表名 modify 列名 类型及约束;

例如:

alter table students modify birth date not null;



image.png


修改表-删除字段

alter table 表名 drop 列名;

例如:删除表中 gender(性别) 字段

alter table students drop gender;


image.png

查看表的创建语句

show create table 表名;

例如:

show create table classes;


image.png

image.png


删除表

drop table 表名;

例如:删除表

drop table students;


image.png


十一、表中数据的增删改查(curd)



curd的解释: 代表 创建(Create)、更新(Update)、读取(Retrieve)和 删除(Delete)


  • 11.1、准备
  • (1)、创建一个班级库:ClassDataBase
create database ClassDataBase charset=utf8;

image.png

(2)、在 班级库:ClassDataBase 里面创建一个学生表 studentTable

,里面创建 4 个字段:id、name、age、gender,提示:gender 是枚举类型

create table studentTable(
      id int unsigned primary key auto_increment not null,
      name varchar(20) default '',
      age tinyint unsigned default 0,
      gender enum('男','女','人妖','保密') default '保密'
);


image.png

image.png


11.2、  加数据



  • 全列插入:有几个字段插入几个,主键字段 可以用 0nulldefault 来占位,枚举可以用 1,2,3,4来代替,如下面的例子中 "男"  可以用 1 来代替,看上图的枚举,男是第一位,枚举有几个最大是几,上面的gender是四个性别,最大是4,超过4报错


insert into 表名 values(value1,value2,value3,.....);
  • 例如:-- 向studentTable表插入 一个学生信息(studentTable是表名)


insert into studentTable values(0, "小王", 26, "男");



image.png

部分插入

insert into 表名(列1名,列2名,...) values(值1,值2,...)

例如:枚举选的4 ,所以是 保密

insert into studentTable (name, gender) values ("小红", 4);



image.png


多行插入

insert into studentTable (name, gender) values ("小李", 3),("小明", 1);
insert into studentTable values(default, "小飞", 20, "女"), (default, "小杜", 20, "男");


image.png

  • 11.4、  变数据(修改数据)
    update 表名 set 列1=值1,列2=值2... where 条件;
    例如:


update studentTable set gender=1; -- 全部都改
update studentTable set gender=2 where name="小王"; -- 只要name是小王的 全部的修改
update studentTable set gender=1 where id=3; -- 只要id为3的 进行修改
update studentTable set age=22, gender=1 where id=3; -- 只要id为3的 进行修改
  • 11.5、  询数据
  • 查询所有列


select * from 表名;
  • 例如:


select * from studentTable;
  • 一定条件下查询


select * from 表名 where 条件; -- 查询 条件 下的所有信息
  • 例如:


select * from studentTable where name="小王"; -- 查询 name为 小王 的所有信息
select * from studentTable where id>2; -- 查询 id > 2 的所有信息
  • 查询指定列


select 列1,列2,... from 表名;
  • 例如:


select name,gender from studentTable;


image.png

可以 使用 as 为 列或表 指定别名

select 字段[as 别名] , 字段[as 别名] from 数据表 where ....;

例如:

select name as 姓名,gender as 性别 from studentTable;


image.png


查询 字段的顺序(哪个在前面就先显示谁)

select id as 序号, gender as 性别, name as 姓名 from studentTable;


image.png


十二、数据库的备份与恢复  参考博客



  • 12.1、备份
    运行mysqldump命令  (下面 python.sql是新的数据库 )


mysqldump –u root –p 数据库名 > fileName.sql;
# 按提示输入mysql的密码


image.png


提示:mysqldump –u root –p 数据库名 > fileName.sql;里面的 python.sql 你可以指定路径,如果不指定就是备份到当前目录


  • 12.2、恢复
    连接mysql,创建新的数据库


mysql -u root -p密码
create database 数据库名 charset=utf8;
quit
  • 退出连接,执行如下命令


mysql -u root –p 上面创建的新数据库名 < fileName.sql
# 根据提示输入mysql密码


提示:fileName.sql 会自动回到当初把它备份出来的地方,名字是你新起的名字


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
5天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第16天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括配置系统源、安装 SQL Server 2019 软件包以及数据库初始化,确保 SQL Server 正常运行。
|
14天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第8天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统准备、配置安装源、安装 SQL Server 软件包、运行安装程序、初始化数据库以及配置远程连接。通过这些步骤,您可以顺利地在 CentOS 系统上部署和使用 SQL Server 2019。
|
16天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
30 4
|
17天前
|
SQL 关系型数据库 MySQL
go语言中安装数据库驱动
【11月更文挑战第1天】
36 5
|
15天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第7天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统要求检查与准备、配置安装源、安装 SQL Server 2019、配置 SQL Server 以及数据库初始化(可选)。通过这些步骤,你可以成功安装并初步配置 SQL Server 2019,进行简单的数据库操作。
|
22天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
64 3
|
11天前
|
运维 关系型数据库 MySQL
安装MySQL8数据库
本文介绍了MySQL的不同版本及其特点,并详细描述了如何通过Yum源安装MySQL 8.4社区版,包括配置Yum源、安装MySQL、启动服务、设置开机自启动、修改root用户密码以及设置远程登录等步骤。最后还提供了测试连接的方法。适用于初学者和运维人员。
105 0
|
14天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
29 1
|
1月前
|
存储 关系型数据库 MySQL
Mysql(4)—数据库索引
数据库索引是用于提高数据检索效率的数据结构,类似于书籍中的索引。它允许用户快速找到数据,而无需扫描整个表。MySQL中的索引可以显著提升查询速度,使数据库操作更加高效。索引的发展经历了从无索引、简单索引到B-树、哈希索引、位图索引、全文索引等多个阶段。
64 3
Mysql(4)—数据库索引
|
23天前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
117 1
下一篇
无影云桌面