mysql关系型数据库的学习

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
简介: mysql关系型数据库的学习

mysql关系型数据库的学习

一、使用终端操作数据库

如何查看有什么数据库?

show databases;

如何选择数据库?

use databaseName;

如何查看数据库中有哪些表

show tables;

如何查询表中的数据

select *from tableName;

如何退出数据库服务器

exit;

如何在数据库服务器中创建自己的数据库

create database databaseName;

如何创建一个数据表?创建一个pet表?

create table pet(
  name varchar(20),
    owner varchar(20),
    specise varchar(20),
    sex char(1),
    birth DATE,
    death DATE
);

NOTE: varchar()和char的区别?

  • char是定长,varchar是不定长的
  • 定义最后一个字段不要加“,”

如何查看数据表结构

desc databasesName;
describe tableName;
 说明:
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
 Field    :    字段的名称
  Type     :    字段的类型,可以有int    var    varchar    
  Key      :    是否是关键字 如可以定义为:  primary key 或者 unique key   ...
Default: :    若是该字段没有主动设置值的时候,该字段的默认值是什么?

如何插入数据

insert into databasesName values();

如何删除数据

//先插入数据
       INSERT INTO pet VALUES('kk1','cc1','dog1','1','1998-1-2',null);
       INSERT INTO pet VALUES('kk2','cc2','dog2','2','1998-2-2',null);
       INSERT INTO pet VALUES('kk3','cc3','dog3','1','1998-3-2','1998-12-2');
       INSERT INTO pet VALUES('kk4','cc4','dog4','2','1998-4-2',null);
//---------------------------------
delete from tableName where 条件;

修改数据

update tableName set 字段1=值1,字段2=值2....where 条件;

总结:

  1. table的操作
  2. 表操作的总结

1.2mysql建表中的约束

  • 主键约束
    它能够唯一确定一张表中的一条记录,增加主键约束之后,就可以使得字段不重复而且不为空 。
create table user(
    id int primary key,
     name varchar(20)
    );

当我们去插入一条数据:

insert into user values(1,'zhangsan');

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6p6RdckN-1647519911436)(https://cdn.jsdelivr.net/gh/JackieLing/mage1/img/20220313094134.png)]

当我们再次重复插入数据时就可以看到主键的作用了:

由于 id是主键,我们不能重复插入id值相等的记录,所以修改一下 id值就可以了:

insert into user values(2,'zhangsan');

//只要联合的主键值加起来不重复就可以
create table user2(
  id int,
    name varchar(20),
    password varchar(20),
    primary key(id,name)
);
INSERT INTO user2 VALUES (1,'老王','123456');
  • 在增加一条就会报错:
INSERT INTO user2 VALUES (1,'老王','123456');
  • 自增约束
create table user3(
  id int primary key auto_increment,
    name varchar(20)
);
  • 先插入数据:
insert into user3(name) values('张三');
insert into user3(name) values('李四');
李四的id 会自增

如果说我们创建表的时侯,忘记添加主键怎么办?

create table user4(
  id int,
    name varchar(20)
);

自己添加主键:

alter table user4 add primary key(id);

删除主键约束:

alter table user4 drop primary key;

修改主键约束:

alter table user4 modify id int primary key;
  • 唯一约束
    约束修饰的字段不能重复。
create table user5(
  id int,
    name varchar(20)
);
alter table user5 add unique(name);
desc user5;

这时候我们插入新数据:

insert into user5 values(1,'zhangsan');
把name改了就可以插入成功!

重复插入:

  • 非空约束
create table user9(
  id int,
    name varchar(20)not  null
);

insert into user9 (id) values(1);
因为name是非空的,所以只插入id是不行的

  • 默认约束
    当我们插入字段值的时候,如果没有传值,就会使用默认值
create table user10(
  id int,
    name varchar(20),
    age int default 10
);

我们只插入id 和name:

insert into user10 (id,name) values(1,'zhangsan');
age是默认设置的

  • 外键约束
    涉及到两个表:父表和子表
    主表、副表。
--班级
create table classes(
  id int primary key,
    name varchar(20)
);
--学生表
create table students(
  id int primary key,
    name varchar(20),
    class_id int,
    foreign key(class_id) references classes(id)
);
insert into classes  values(1,'一班');
insert into classes  values(2,'二班');
insert into classes  values(3,'三班');
insert into classes  values(4,'四班');

insert into students  values(1001,'张三',1);
insert into students  values(1002,'张三',2);
insert into students  values(1003,'张三',3);
insert into students  values(1004,'张三',4);

主表中的记录被副表引用,是不可以被删除的。

dn.jsdelivr.net/gh/JackieLing/mage1/img/20220313171103.png" />

insert into students  values(1001,'张三',1);
insert into students  values(1002,'张三',2);
insert into students  values(1003,'张三',3);
insert into students  values(1004,'张三',4);

[外链图片转存中…(img-5spALn4O-1647519911446)]

主表中的记录被副表引用,是不可以被删除的。

delete from classes where id=4;是不能被执行的,因为classes中的id被students表中的id引用了。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
6月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
469 158
|
6月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1116 152
|
6月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎
阿里云数据库RDS支持MySQL、SQL Server、PostgreSQL和MariaDB引擎,提供高性价比、稳定安全的云数据库服务,适用于多种行业与业务场景。
859 156
|
6月前
|
Cloud Native 关系型数据库 MySQL
免费体验!高效实现自建 MySQL 数据库平滑迁移至 PolarDB-X
PolarDB-X 是阿里云推出的云原生分布式数据库,支持PB级存储扩展、高并发访问与数据强一致,助力企业实现MySQL平滑迁移。现已开放免费体验,点击即享高效、稳定的数据库升级方案。
免费体验!高效实现自建 MySQL 数据库平滑迁移至 PolarDB-X
|
5月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
691 6
|
6月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
6月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
6月前
|
SQL 关系型数据库 MySQL
Mysql数据恢复—Mysql数据库delete删除后数据恢复案例
本地服务器,操作系统为windows server。服务器上部署mysql单实例,innodb引擎,独立表空间。未进行数据库备份,未开启binlog。 人为误操作使用Delete命令删除数据时未添加where子句,导致全表数据被删除。删除后未对该表进行任何操作。需要恢复误删除的数据。 在本案例中的mysql数据库未进行备份,也未开启binlog日志,无法直接还原数据库。
|
SQL Java 数据库连接
MySQL---数据库从入门走向大神系列(十五)-Apache的DBUtils框架使用
MySQL---数据库从入门走向大神系列(十五)-Apache的DBUtils框架使用
490 0
MySQL---数据库从入门走向大神系列(十五)-Apache的DBUtils框架使用
|
SQL 关系型数据库 MySQL
MySQL---数据库从入门走向大神系列(六)-事务处理与事务隔离(锁机制)
MySQL---数据库从入门走向大神系列(六)-事务处理与事务隔离(锁机制)
292 0
MySQL---数据库从入门走向大神系列(六)-事务处理与事务隔离(锁机制)

推荐镜像

更多