MySQL基础(表操作与)连接


1、 表操作

1.1.MySQL表数据类型

参考连接:http://www.runoob.com/mysql/mysql-data-types.html

  • 数值类型:
    在这里插入图片描述
  • 日期和时间类型

在这里插入图片描述

  • 字符串类型
    在这里插入图片描述

1.2.用SQL语句创建表

  • 语句解释
CREATE TABLE table_name (column_name column_type);

创建在数据库中创建表明table_name,列名column_name,以及每列的数据类型column_type

  • 设定列类型 、大小、约束与设置主键
CREATE TABLE IF NOT EXISTS `course`(
   `student_id` INT UNSIGNED AUTO_INCREMENT,
   `student_name` VARCHAR(100) NOT NULL,
   `student_calss` VARCHAR(100) NOT NULL,
   `student_date` DATE,
   PRIMARY KEY ( `student_id` )
)ENGINE=InnoDB DEFAULT CHARSET=utf8;

如果你不想字段为 NULL 可以设置字段的属性为 NOT NULL,
在操作数据库时如果输入该字段的数据为NULL ,就会报错。
AUTO_INCREMENT定义列为自增的属性,一般用于主键,数值会自动加1。
PRIMARY KEY关键字用于定义列为主键。 您可以使用多列来定义主键,列间以逗号分隔。
ENGINE 设置存储引擎,CHARSET 设置编码。

建立表格如下:
在这里插入图片描述
常见的约束:

  • 非空约束,not null,针对某个字段设置其值不为空,如学生姓名不为空.
  • 唯一约束,unique,它可以使某个字段的值不能重复,如email不能重复
  • 主键约束,primary key,主键可以标识记录的唯一性,主键分为单一主键和复合(联合)主键,单一主键是由一个字段构成的,复合(联合)主键是由多个字段构成的。
  • 外键约束,foreign key,外键主要是维护表之间的关系的,主要是为了保证参照完整性,如果表中的某个字段为外键字段,那么该字段的值必须来源于参照的表的主键。

1.3. 用SQL语句向表中添加数据

  • 语句解释

以下为向MySQL数据表插入数据通用的 INSERT INTO SQL语法:

INSERT INTO table_name ( field1, field2,...fieldN )
                       VALUES
                       ( value1, value2,...valueN );
  • 多种添加方式(指定列名;不指定列名)
    制度列名:

在这里插入图片描述

不指定列名:
在这里插入图片描述


1.4. 用SQL语句删除表

  • 语句解释

以下为删除MySQL数据表的通用语法:

DROP TABLE table_name ;
-- 删除表全部数据和表结构,立刻释放磁盘空间,不管是 Innodb 和 MyISAM;
truncate table table_name;
--删除表全部数据,保留表结构,立刻释放磁盘空间.不管是 Innodb 和 MyISAM;
delete from table_name ;
--删除表全部数据,表结构不变,对于 MyISAM 会立刻释放磁盘空间,InnoDB 不会释放磁盘空间;
delete from table_name where xxx ;
--带条件的删除,表结构不变,不管是 innodb 还是 MyISAM 都不会释放磁盘空间;

1.5. 用SQL语句修改表

  • 修改列名
ALTER TABLE 表名 CHANGE 原列名 新列名 数据类型 约束

在这里插入图片描述

  • 改变数据类型
ALTER TABLE 表名字 MODIFY 列名字 新数据类型;
  • 修改表中数据
update table1 set field1=value1 where 范围

在这里插入图片描述

  • 删除行
delete from 表名 where 范围

在这里插入图片描述

  • 删除列
alter table 表名 drop column 列名;

在这里插入图片描述

  • 新建列
lter table 表名 add column 列名 类型

在这里插入图片描述


2、 表联结

参考:https://www.yiibai.com/mysql/alias.html

  • MySQL别名

有时,列的名称是一些表达式,使查询的输出很难理解。要给列一个描述性名称,可以使用列别名。

SELECT 
 [column_1 | expression] AS descriptive_name
FROM table_name;

在这里插入图片描述

  • INNER JOIN

INNER JOIN(内连接,或等值连接):获取两个表中字段匹配关系的记录
在这里插入图片描述
在这里插入图片描述

  • LEFT JOIN
    获取左表所有记录,即使右表没有对应匹配的记录。

在这里插入图片描述

  • CROSS JOIN

交叉连接,得到的结果是两个表的乘积,即笛卡尔积
笛卡尔(Descartes)乘积又叫直积。假设集合A={a,b},集合B={0,1,2},则两个集合的笛卡尔积为{(a,0),(a,1),(a,2),(b,0),(b,1), (b,2)}。
可以扩展到多个集合的情况。类似的例子有,如果A表示某学校学生的集合,B表示该学校所有课程的集合,则A与B的笛卡尔积表示所有可能的选课情况。

在这里插入图片描述

  • 自连接
    参考:https://www.cnblogs.com/weichao1996/articles/8519973.html
    自连接是连接的一种用法,但并不是连接的一种类型,因为他的本质是把一张表当成两张表来使用。
    mysql有时在信息查询时需要进行对自身连接(自连接),所以我们需要为表定义别名。
    我们举例说明,下面是商品采购表,我们需要找到采购价格比惠惠高的所有信息。

  • UNION
    MySQL UNION 操作符用于连接两个以上的 SELECT 语句的结果组合到一个结果集合中。多个 SELECT 语句会删除重复的数据。

select * from A union all select * from B  //A B数据结构一定要一样

在这里插入图片描述

  • 以上几种方式的区别和联系
    在这里插入图片描述

作业

  • 项目五
    组合两张表 (难度:简单)
    在数据库中创建表1和表2,并各插入三行数据(自己造)
    表1:
    Person
    ±------------±--------+
    | 列名 | 类型 |
    ±------------±--------+
    | PersonId | int |
    | FirstName | varchar |
    | LastName | varchar |
    ±------------±--------+
    PersonId 是上表主键
    表2:
    Address
    ±------------±--------+
    | 列名 | 类型 |
    ±------------±--------+
    | AddressId | int |
    | PersonId | int |
    | City | varchar |
    | State | varchar |
    ±------------±--------+
    AddressId 是上表主键编写一个 SQL 查询,满足条件:无论 person 是否有地址信息,都需要基于上述两表提供 person 的以下信息:FirstName, LastName, City, State
CREATE TABLE Person(
 Personld int,
 FirstName varchar(10),
 Last_name varchar(10),
 PRIMARY KEY (personld)
);
CREATE TABLE Address(
 Addressld int,
 Personld int,
 City varchar(10),
 State varchar(10),
 PRIMARY KEY (Addressld)
 );

在这里插入图片描述

在这里插入图片描述
项目六:

删除重复的邮箱(难度:简单)
编写一个 SQL 查询,来删除 email 表中所有重复的电子邮箱,重复的邮箱里只保留 Id 最小 的那个。
±—±--------+
| Id | Email |
±—±--------+
| 1 | a@b.com |
| 2 | c@d.com |
| 3 | a@b.com |
±—±--------+
Id 是这个表的主键。例如,在运行你的查询语句之后,上面的 Person表应返回以下几行:
±—±-----------------+
| Id | Email |
±—±-----------------+
| 1 | a@b.com |
| 2 | c@d.com |
±—±-----------------+

在这里插入图片描述

在这里插入图片描述


参考
[1][http://www.runoob.com/mysql/mysql-data-types.html]
[2][https://www.yiibai.com/mysql/alias.html]
[3][https://www.cnblogs.com/weichao1996/articles/8519973.html]

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值