【MySQL】表的操作

1. 创建表

create table table_name (
	fieId1 datatype,
	fieId2 datatype,
	fieId3 datatype
) [character set 字符集] [collate 校验规则] [engine 存储引擎];

说明:

  • fieId表示列名;
  • datatype 表示列的类型;
  • character set 字符集,如果没有指定字符集,那么就默认继承该表所在数据库的字符集;
  • collate 校验规则,如果没有指定校验规则,那么就默认继承该表所在数据库的校验规则;
  • engine 存储引擎,如果没有指定存储引擎,那么就默认继承该表所在数据库的存储引擎;

image-20241003000257653

上图例子中,创建了一个指定utf8字符集和utf8_general_ci校验集和MyISAM存储引擎的表,同时再创建一个存储引擎为innodb的表,观察目录结构

image-20241003000616511

可以发现,不同的存储引擎,创建表的文件不一样

  • 对于MyISAM存储引擎,创建的文件有三个
    • table_name.frm:表结构
    • table_name.MYD:表数据
    • table_name.MYI:表索引
  • 对于innodb存储引擎,创建的文件有两个
    • table_name.frm:表结构
    • table_name.idb:表数据和表索引

这是因为底层存储的数据结构不一样

2. 查看表

2.1 查看数据库中所有表

show tables;

image-20241003005006201

2.2 查看表结构

desc table_name

image-20241003001133704

3. 修改表

在项目实际开发中,经常修改某个表的结构,比如字段名字,字段大小,字段类型,表的字符集类型,表的存储引擎等等。我们还有需求,添加字段,删除字段等等。这时我们就需要修改表(虽然大家都很讨厌修改,但是甲方爸爸最大嘛)

alter table table_name add (column datatype [defalut expr][, column datatype] ...); -- 添加列
alter table table_name modify (column datatype [defalut expr][, column datatype] ...); -- 修改列
alter table table_name drop (column); -- 删除列
  • 案例:对于下列结构的表进行修改

image-20241003003947942

1. 添加一个保存文件路径的字段

alter table users add assets varchar(100) comment '图片路径' after birthday;
-- 插入列名为assets的一列,在birthday之后,其中comment表示注释当前列

image-20241003004251827

如上所示,插入成功,并且插入新字段对原来表中数据没有影响

2. 修改name的长度最大为60

alter table users modify name varchar(60);

image-20241003004423800

3. 删除password列

注意:删除字段一定要小心,字段删除后其列对应的所有数据都将会被删除

alter table users drop password;

image-20241003004615082

4. 修改表名为employee

alter table users rename to employee; -- 这里to可以省略

image-20241003004837735

5. 修改列名为xingming

alter table employee change name xiaoming varchar(60); -- 新字段需要完整定义(覆盖式的更新)

image-20241003005112993

4. 删除表

drop [temporary] table [if exists] table_name

image-20241003005201777


本节完…

drop [temporary] table [if exists] table_name

在这里插入图片描述


本节完…

### 回答1: MySQL分库分是一种常用的水平扩展数据库的方法,它将一个大的数据库按照一定的规则分成多个小的数据库,每个小的数据库再按照一定的规则分成多个小的,从而达到分布式存储和负载均衡的目的。 下面是一个基本的分库分方案: 1. 水平分库 将一个大的数据库按照某种规则分成多个小的数据库,例如按照用户ID取模进行分库,将用户ID为奇数的用户存储在一个数据库中,将用户ID为偶数的用户存储在另一个数据库中。需要注意的是,分库后不同的数据库之间要保证数据的一致性,可以通过主从复制或者分布式事务来保证。 2. 水平分 将一个小的数据库按照某种规则分成多个小的,例如按照时间进行分,将不同时间段的数据存储在不同的中。需要注意的是,分后不同的之间要保证数据的一致性,可以通过分布式锁或者分布式事务来保证。 3. 垂直分 将一个大的按照某种规则拆分成多个小的,例如将相对独立的字段分成一个,将经常更新的字段分成一个。需要注意的是,分后需要通过JOIN操作来获取完整的数据,可能会影响查询性能。 总之,分库分是一种比较复杂的技术,需要根据具体情况进行设计和实现。建议在实际应用中采用成熟的分库分中间件,例如ShardingSphere、TDDL等。 ### 回答2: MySQL分库分是将一个大型的数据库按照一定的规则拆分成多个小的数据库,以提高数据库的性能和扩展性。 分库分的方法有两大类:垂直拆分和水平拆分。 垂直拆分是将一个大的数据库按照业务功能或者数据类型分成多个小的数据库。比如将用户数据、订单数据等不同的业务数据存放在不同的数据库中。 水平拆分是将一个大的按照一定的规则拆分成多个小的。一般通过hash、range或者列等方式进行拆分。比如按照用户ID的hash值来拆分用户数据,或者按照订单的创建时间范围来拆分订单数据。 在使用分库分的过程中,需要考虑以下几个方面: 1. 数据一致性:需要确保拆分后的库之间的数据一致性。可以通过分布式事务或者通过应用程序来保证数据的一致性。 2. 查询路由:在进行数据查询时,需要确定对应的查询路由规则,将查询路由到正确的数据库中。 3. 数据迁移:在进行分库分之前,需要将现有的数据进行迁移。可以使用工具进行数据迁移,或者通过应用程序将数据重新插入到分库分中。 4. 垂直拆分和水平拆分的选择:根据业务需求和数据库性能来选择合适的拆分方式。 5. 分库分的动态性:根据业务需求,可能需要对分库分进行动态调整,需要考虑如何动态调整和迁移数据。 6. 分布式事务的处理:如果涉及到多个数据库的事务处理,需要考虑分布式事务的处理方式。 总之,MySQL的分库分可以通过垂直拆分和水平拆分的方式将一个大型的数据库分成多个小的数据库,以提高数据库的性能和扩展性。但在进行分库分之前,需要考虑数据一致性、查询路由、数据迁移等问题。 ### 回答3: MySQL进行分库分可以采用垂直分库和水平分的方式。 垂直分库是将原始数据库按照不同的业务功能或业务模块划分为多个独立的数据库。这样每个数据库只存储与其相关的数据,分离了数据的关联性,提高了数据库的性能和扩展能力。垂直分库可以按照功能拆分,比如将用户相关的数据存放在一个库中,将订单相关的数据存放在另一个库中,以此类推。分库后可以根据业务的发展和负载的变化,对不同的库进行独立扩容,提高了系统的稳定性和可靠性。 水平分是将单一的数据库按照某种规则拆分为多个子,每个子只包含一部分数据。拆分的规则可以是按照某个字段进行拆分,比如按照用户ID、日期等字段,也可以是按照均匀分布的方式进行拆分。水平分可以提高数据库的读写性能,分散了数据的压力。在查询时,可以根据查询条件将查询请求发送到不同的分进行查询,最后再将结果合并返回。在新增数据时,可以根据规则将数据插入到相应的分中,实现数据的均衡存储。 在实际应用中,可以根据系统的需求和数据的规模选择适合的分库分方案。在进行分库分时,需要考虑到数据一致性、跨库查询和业务拆分等问题,并合理规划数据库的关联性和数据的拆分规则。同时还需要注意分库分带来的管理和维护复杂性,比如跨库事务、分查询等问题,并选择合适的工具和解决方案进行支持和优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

凌云志.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值