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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 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
目录
相关文章
|
4天前
|
存储 关系型数据库 MySQL
2022年最新最详细的MYSQL数据库安装(详细图解过程、毕成功)
这篇文章提供了2022年最新最详细的MYSQL数据库安装教程,包括下载、安装步骤图解、初始化配置文件创建、登录密码修改注意事项,并分享了作者在安装过程中遇到的常见问题及其解决方法。
2022年最新最详细的MYSQL数据库安装(详细图解过程、毕成功)
|
3天前
|
关系型数据库 Java MySQL
Linux安装JDK1.8 & tomcat & MariaDB(MySQL删减版)
本教程提供了在Linux环境下安装JDK1.8、Tomcat和MariaDB的详细步骤。这三个组件的组合为Java Web开发和部署提供了一个强大的基础。通过遵循这些简单的指导步骤,您可以轻松建立起一个稳定、高效的开发和部署环境。希望这个指导对您的开发工作有所帮助。
25 8
|
3天前
|
SQL NoSQL 数据库
在Python中使用sqlalchemy来操作数据库的几个小总结
在探索使用 FastAPI, SQLAlchemy, Pydantic,Redis, JWT 构建的项目的时候,其中数据库访问采用SQLAlchemy,并采用异步方式。数据库操作和控制器操作,采用基类继承的方式减少重复代码,提高代码复用性。在这个过程中设计接口和测试的时候,对一些问题进行跟踪解决,并记录供参考。
|
1天前
|
关系型数据库 MySQL Java
centos7安装mysql教程及Navicat平替软件
【8月更文挑战第17天】本教程详述CentOS 7上安装MySQL的过程。首先确保移除任何预装的MySQL组件,然后通过wget获取并安装MySQL的YUM源。可以选择安装特定版本如5.7或8.0。安装MySQL服务器后,启动服务并查找初始密码。登录MySQL后应立即更改密码,并可根据需要设置远程访问权限。此外,还推荐使用免费开源的DBeaver作为数据库管理工具,提供了安装步骤以方便管理和操作MySQL数据库。
|
1天前
|
关系型数据库 MySQL Linux
数据类型和运算符(MySQL服务器的安装,MySQL客户端,数据类型,运算符,MySQL的语法规范)
无论是对于初学者还是有经验的开发者,了解MySQL的安装、客户端使用、数据类型、运算符和语法规范都是至关重要的。这不仅有助于高效地管理和查询数据,而且对于设计和实现数据库解决方案来说是基础工作。通过深入学习和实践这些知识,您可以更好地发挥MySQL数据库的强大功能。
8 2
|
1天前
|
关系型数据库 MySQL Linux
一文教会你如何在Linux系统中使用Docker安装Mysql 5.7版本 【详细过程+图解】
这篇文章提供了在Linux系统中使用Docker安装Mysql 5.7版本的详细过程和图解,包括安装指定版本、创建实例、启动、使用Navicat连接测试、文件挂载与端口映射、进入容器、配置文件修改以及重新启动容器等步骤。
一文教会你如何在Linux系统中使用Docker安装Mysql 5.7版本 【详细过程+图解】
|
3天前
|
网络协议 安全 Unix
6! 用Python脚本演示TCP 服务器与客户端通信过程!
6! 用Python脚本演示TCP 服务器与客户端通信过程!
|
3月前
|
Web App开发 测试技术 Python
【如何学习python自动化测试】—— 浏览器驱动的安装 以及 如何更新driver
【如何学习python自动化测试】—— 浏览器驱动的安装 以及 如何更新driver
55 0
|
3月前
|
数据采集 自然语言处理 搜索推荐
一篇博客带你领略学习Python的第三方库---如何获取和安装第三方库,关于三种常见第三方库的下载和讲解(pyinstall库,jieba库,wordcloud库),更多第三方库的分类介绍
一篇博客带你领略学习Python的第三方库---如何获取和安装第三方库,关于三种常见第三方库的下载和讲解(pyinstall库,jieba库,wordcloud库),更多第三方库的分类介绍
|
3月前
|
存储 NoSQL MongoDB
学习如何使用 Python 连接 MongoDB: PyMongo 安装和基础操作教程
Python 需要一个 MongoDB 驱动程序来访问 MongoDB 数据库。我将使用 MongoDB 驱动程序 PyMongo 建议您使用 PIP 来安装 PyMongo。PIP 很可能已经安装在您的 Python 环境中。将命令行导航到 PIP 的位置,然后键入以下内容:
141 1