首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

数据库 SQL 开发和操作行为规范

数据库设计时,应该要对以后扩展进行考虑 5. 程序连接不同的数据库使用不同的账号,禁止跨库查询 为数据库迁移和分库分表留出余地 降低业务耦合度 避免权限过大而产生的安全风险 6....在 MySQL 中,对于同一个 SQL 多关联(join)一个表,就会多分配一个关联缓存,如果在一个 SQL 中关联的表越多,所占用的内存也就越大。...1.1 binlog 日志为 row 格式时会产生大量的日志: 大批量写操作会产生大量日志,特别是对于 row 格式二进制数据而言,由于在 row 格式中会记录每一行数据的修改,我们一次修改的数据越多,...使用 pt-online-schema-change;首先会建立一个与原表结构相同的新表,并且在新表上进行表结构的修改,然后再把原表中的数据复制到新表中,并在原表中增加一些触发器。...把原表中新增的数据也复制到新表中,在行所有数据复制完成之后,把新表命名成原表,并把原来的表删除掉。把原来一个 DDL 操作,分解成多个小的批次进行。 3.

1.3K51

值得收藏:一份非常完整的 MySQL 规范(二)

区分度最高的放在联合索引的最左侧(区分度 = 列中不同值的数量 / 列的总行数)。 尽量把字段长度小的列放在联合索引的最左侧(因为字段长度越小,一页能存储的数据量越大,IO 性能也就越好)。...在 MySQL 中,对于同一个 SQL 多关联(join)一个表,就会多分配一个关联缓存,如果在一个 SQL 中关联的表越多,所占用的内存也就越大。...,由于在 row 格式中会记录每一行数据的修改,我们一次修改的数据越多,产生的日志量也就会越多,日志的传输和恢复所需要的时间也就越长,这也是造成主从延迟的一个原因。...pt-online-schema-change 它会首先建立一个与原表结构相同的新表,并且在新表上进行表结构的修改,然后再把原表中的数据复制到新表中,并在原表中增加一些触发器。...把原表中新增的数据也复制到新表中,在行所有数据复制完成之后,把新表命名成原表,并把原来的表删除掉,把原来一个 DDL 操作,分解成多个小的批次进行。 3.

1.1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql学习总结04 — SQL数据操作

    ,只要使用 "数据库.表名",就可以在任何数据库下访问其他数据库的表名 命令:create table 新表名> like 表名>; 注:更多建表操作见附录 2.4 表字段操作 增加字段: 命令:alter...纵向合并,字段数不变,多个查询的记录数合并 9.1 应用场景 将同一张表中不同的结果(需要对应多条查询语句来实现),合并到一起展示数据 最常见:在数据量大的情况下对表进行分表操作,需要对每张表进行部分数据统计...+ 第二张表字段数 内连接:inner join,从一张表中取出所有的记录去另外一张表中匹配:利用匹配条件进行匹配,成功了保留,失败了放弃 流程: 从第一张表中取出一条记录,然后去另外一张表中进行匹配...join右边为主表 2、 拿主表的每一条记录,去匹配另外一张表(从表)的每一条记录 3、 如果满足匹配条件:保留;不满足即不保留 4、 如果主表记录在从表中一条都没有匹配成功,那么也要保留该记录:从表对应的字段值都为...的前提是对应的两张表连接的字段同名(类似自然连接自动匹配) 如果使用using关键字,对应的同名字段在结果中只会保留一个 基本语法:表1> inner,left,right join 表2> using

    5.2K30

    MySQL规范

    数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql的保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要做到见名识意...,建议控制在500w内,过大会造成修改表结构,备份,恢复都会有很大的问题 谨慎使用MySQL分区表 尽量做到冷热数据分离,减少表的宽度 常用数据在一个表,读取频次少的数据在另一个表 禁止在表中设置预留字段...在Mysql中,对于同一个SQL多关联(join)一个表,就会多分配一个关联缓存,如果在一个SQL中关联的表越多,所占用的内存也就越大。...pt-online-schema-change它会首先建立一个与原表结构相同的新表,并且在新表上进行表结构的修改,然后再把原表中的数据复制到新表中,并在原表中增加一些触发器。...把原表中新增的数据也复制到新表中,在行所有数据复制完成之后,把新表命名成原表,并把原来的表删除掉。 把原来一个DDL操作,分解成多个小的批次进行。

    1.3K20

    这是我见过最有用的Mysql面试题,面试了无数公司总结的(内附答案)

    数据仓库是指来自多个信息源的中央数据存储库。 这些数据经过整合,转换,可用于采矿和在线处理。 3.什么是数据库中的表? 表是一种数据库对象,用于以保留数据的列和行的形式将记录存储在并行中。...4.什么是数据库中的细分? 数据库表中的分区是分配用于在表中存储特定记录的空间。 5.什么是数据库中的记录? 记录(也称为数据行)是表中相关数据的有序集合。 6.什么是表中的列?...SELECT:从数据库中选择特定数据 INSERT:将新记录插入表中 UPDATE:更新现有记录 DELETE:从表中删除现有记录 15. SQL中有哪些不同的DCL命令?...在SQL Server中,数据库表中的每一列都有一个名称和一种数据类型。 在创建SQL表时,我们需要决定在表的每一列中存储哪种数据类型。 57.可以在BOOLEAN数据字段中存储哪些可能的值?...以下是ACID的四个属性。这些保证了数据库事务的可靠处理。 原子性 一致性 隔离 耐用性 62.定义SELECT INTO语句。 SELECT INTO语句将数据从一个表复制到新表中。

    27.1K20

    值得收藏:一份非常完整的 MySQL 规范(二)

    在 MySQL 中,对于同一个 SQL 多关联(join)一个表,就会多分配一个关联缓存,如果在一个 SQL 中关联的表越多,所占用的内存也就越大。...,由于在 row 格式中会记录每一行数据的修改,我们一次修改的数据越多,产生的日志量也就会越多,日志的传输和恢复所需要的时间也就越长,这也是造成主从延迟的一个原因。...避免产生大事务操作 大批量修改数据,一定是在一个事务中进行的,这就会造成表中大批量数据进行锁定,从而导致大量的阻塞,阻塞会对 MySQL 的性能产生非常大的影响。...pt-online-schema-change 它会首先建立一个与原表结构相同的新表,并且在新表上进行表结构的修改,然后再把原表中的数据复制到新表中,并在原表中增加一些触发器。...把原表中新增的数据也复制到新表中,在行所有数据复制完成之后,把新表命名成原表,并把原来的表删除掉,把原来一个 DDL 操作,分解成多个小的批次进行。 3.

    65410

    mysql基础知识(7)

    因为每次插入新记录时,都需要确保自增 ID 的唯一性和递增性,在高并发场景下,获取新的自增 ID 的操作可能会存在一定的串行化,从而导致性能下降。...Read View包含了当前系统中活跃的事务ID集合、最小活跃事务ID、下一个要分配的事务ID等信息。...写操作: 在InnoDB中,写操作仍然需要加锁(通常是行级锁),以保证数据的一致性。 写操作会更新数据并生成新的undo日志,同时更新DB_TRX_ID和DB_ROLL_PTR字段。...right join 右连接,在两张表进行连接查询时,会返回右表所有的行,即使在左表中没有匹配的记录。 说一下数据库的三大范式 第一范式:数据表中的每一列(每个字段)都不可以再拆分。...使用临时表: 如果需要保留部分数据而删除其他数据,可以考虑使用临时表。 将需要保留的数据插入到临时表中,然后清空原表,最后将临时表中的数据重新插入到原表中。

    7411

    MySQL8 中文参考(八十)

    通常可以从具有特定数据类型的列复制到具有相同类型和大小或宽度的另一列,如适用,或更大的列。...在某些情况下,还可以从源表中具有一种数据类型的列复制到副本中具有不同数据类型的列;当源表中列的数据类型提升为副本中相同大小或更大的类型时,这称为属性提升。...例如,在 MySQL 5.7 源上命名为 rank 的表列在复制到 MySQL 8.0 副本时可能会导致问题,因为 RANK 是 MySQL 8.0 中的保留字。...当此变量为ON时,对于事务中发生的任何非事务语句,立即记录(不仅仅是初始的非事务语句)。其他语句被保留在事务缓存中,并在事务提交时记录。...因此,应该注意确保视图不会复制通常出于安全原因而被过滤的表数据。 使用基于语句的日志记录支持从表复制到同名视图,但在使用基于行的日志记录时不支持。在启用基于行的日志记录时尝试这样做会导致错误。

    13510

    Uber为什么放弃Postgres选择迁移到MySQL?

    其他字段... 我们通过一个简单的用户表来解释这个。对于每个用户,我们都有一个自动递增的用户 ID 主键、用户的名字和姓氏以及用户的出生年份。...因此,我们可以这样考虑表的内部表示形式: 主键索引(将 id 映射到 ctid)的定义如下: B 树索引是在 id 字段上定义的,并且 B 树中的每个节点都存有 ctid 的值。...请注意,在这种情况下,由于使用了自动递增的 ID,B 树中字段的顺序恰好与表中的顺序相同,但并不是一直都这样。 二级索引看起来差不多,主要区别在于字段的存储顺序不同,因为 B 树必须按字典顺序来组织。...假设我们需要更新该表中的一条记录,比如我们要更新 al-Khwārizmī的出生年份。如前所述,行的元组是不可变的。因此,为了更新记录,我们向表中添加了一个新的元组。...如果空间足够,id 为 4 的那一行数据中的出生年份字段会进行原地更新(实际上,这个更新总是发生在原地,因为出生年份是一个占用固定空间量的整数)。出生年份索引也进行原地更新。旧数据行将被复制到回滚段。

    2.9K10

    值得收藏:一份非常完整的 MySQL 规范

    一、数据库命令规范 · 所有数据库对象名称必须使用小写字母并用下划线分割 · 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) · 数据库对象的命名要能做到见名识意...IO) 更有效的利用缓存,避免读入无用的冷数据 经常一起使用的列放到一个表中(避免更多的关联操作) 7、禁止在表中建立预留字段 预留字段的命名很难做到见名识义 预留字段无法确认存储的数据类型,所以无法选择合适的类型...在Mysql中,对于同一个SQL多关联(join)一个表,就会多分配一个关联缓存,如果在一个SQL中关联的表越多,所占用的内存也就越大。...pt-online-schema-change它会首先建立一个与原表结构相同的新表,并且在新表上进行表结构的修改,然后再把原表中的数据复制到新表中,并在原表中增加一些触发器。...把原表中新增的数据也复制到新表中,在行所有数据复制完成之后,把新表命名成原表,并把原来的表删除掉。 把原来一个DDL操作,分解成多个小的批次进行。

    97330

    值得收藏:一份非常完整的 MySQL 规范

    3、所有表和字段都需要添加注释 使用comment从句添加表和列的备注 从一开始就进行数据字典的维护 4、尽量控制单表数据量的大小,建议控制在500万以内 500万并不是MySQL数据库的限制,过大会造成修改表结构...(表越宽,把表装载进内存缓冲池时所占用的内存也就越大,也会消耗更多的IO) 更有效的利用缓存,避免读入无用的冷数据 经常一起使用的列放到一个表中(避免更多的关联操作) 7、禁止在表中建立预留字段 预留字段的命名很难做到见名识义...在Mysql中,对于同一个SQL多关联(join)一个表,就会多分配一个关联缓存,如果在一个SQL中关联的表越多,所占用的内存也就越大。...pt-online-schema-change它会首先建立一个与原表结构相同的新表,并且在新表上进行表结构的修改,然后再把原表中的数据复制到新表中,并在原表中增加一些触发器。...把原表中新增的数据也复制到新表中,在行所有数据复制完成之后,把新表命名成原表,并把原来的表删除掉。 把原来一个DDL操作,分解成多个小的批次进行。

    76230

    值得收藏:一份非常完整的 MySQL 规范

    3、所有表和字段都需要添加注释 使用comment从句添加表和列的备注 从一开始就进行数据字典的维护 4、尽量控制单表数据量的大小,建议控制在500万以内 500万并不是MySQL数据库的限制,过大会造成修改表结构...(表越宽,把表装载进内存缓冲池时所占用的内存也就越大,也会消耗更多的IO) 更有效的利用缓存,避免读入无用的冷数据 经常一起使用的列放到一个表中(避免更多的关联操作) 7、禁止在表中建立预留字段 预留字段的命名很难做到见名识义...在Mysql中,对于同一个SQL多关联(join)一个表,就会多分配一个关联缓存,如果在一个SQL中关联的表越多,所占用的内存也就越大。...pt-online-schema-change它会首先建立一个与原表结构相同的新表,并且在新表上进行表结构的修改,然后再把原表中的数据复制到新表中,并在原表中增加一些触发器。...把原表中新增的数据也复制到新表中,在行所有数据复制完成之后,把新表命名成原表,并把原来的表删除掉。 把原来一个DDL操作,分解成多个小的批次进行。

    90130

    mysql binlog应用场景与原理深度剖析

    复制允许将来自一个MySQL数据库服务器(master) 的数据复制到一个或多个其他MySQL数据库服务器(slave),以实现灾难恢复、水平扩展、统计分析、远程数据分发等功能。...例如笔者,曾经因为误操作污染了业务方几十万数据记录。 如何将脏数据恢复成原来的样子?如果恢复已经被删除的记录? 这些都可以通过反解binlog来完成,笔者也是通过这个手段,来恢复业务方的记录。...在实际生产环境中,一般无法保留所有的历史binlog。因为一条记录可能会变更多次,记录依然是一条,但是对应的binlog事件就会有多个。在数据变更比较频繁的情况下,就会产生大量的binlog文件。...接着,我们看到了一个Table_map 事件,就是前面提到的TABLE_MAP_EVENT,在INFO列,我们可以看到其记录table_id为108,操作的是test库中user表。...我们看到了WHERE以及SET子句中,并没有直接列出字段名,而是以@1、@2这样的表示字段位于数据库表中的顺序。

    2.7K30

    MySQ之onlineDDL

    DDL 的算法 copy COPY是MYSQL 5.5以及之前的默认算法,使用COPY算法会锁表,不支持online ddl,COPY算法在server层创建一个临时表用于copy数据,最后用新表替换旧表...按照原表的定义创建一个新的临时表2.对原表加写锁3.对新的临时表进行修改4.将原表中的数据逐行复制到新表中5.释放原表的写锁6.将旧表删除,并将新的临时表重命名RENAME 大 修改列的数据类型 INPLACE...( rebuild table) 由 InnoDB 引擎完成,涉及数据变更,需要重建聚簇索引(而不是像 COPY 那种方式把数据一行行从原表复制到新表) 中 删除列 INPLACE( no rebuild...如果不使用自增ID做主键,插入新数据是乱序的,存储引擎不得不频繁的做页分裂操作,以便为新的行分配空间。...但如果是自增ID,下一条记录就会写入新的页中,一旦数据按照这种顺序的方式加载,主键页就会近乎于顺序的记录填满,提升了页面的最大填充率,不会有页的浪费。

    9110

    mysql binlog应用场景与原理深度剖析

    复制允许将来自一个MySQL数据库服务器(master) 的数据复制到一个或多个其他MySQL数据库服务器(slave),以实现灾难恢复、水平扩展、统计分析、远程数据分发等功能。...例如笔者,曾经因为误操作污染了业务方几十万数据记录。 如何将脏数据恢复成原来的样子?如果恢复已经被删除的记录? 这些都可以通过反解binlog来完成,笔者也是通过这个手段,来恢复业务方的记录。...在实际生产环境中,一般无法保留所有的历史binlog。因为一条记录可能会变更多次,记录依然是一条,但是对应的binlog事件就会有多个。在数据变更比较频繁的情况下,就会产生大量的binlog文件。...接着,我们看到了一个Table_map 事件,就是前面提到的TABLE_MAP_EVENT,在INFO列,我们可以看到其记录table_id为108,操作的是test库中user表。...我们看到了WHERE以及SET子句中,并没有直接列出字段名,而是以@1、@2这样的表示字段位于数据库表中的顺序。

    81611

    MySQL 高性能优化规范建议

    数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用 MySQL 保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意...禁止在表中建立预留字段 预留字段的命名很难做到见名识义。 预留字段无法确认存储的数据类型,所以无法选择合适的类型。 对预留字段类型的修改,会对表进行锁定。 8....在 MySQL 中,对于同一个 SQL 多关联(join)一个表,就会多分配一个关联缓存,如果在一个 SQL 中关联的表越多,所占用的内存也就越大。...pt-online-schema-change 它会首先建立一个与原表结构相同的新表,并且在新表上进行表结构的修改,然后再把原表中的数据复制到新表中,并在原表中增加一些触发器。...把原表中新增的数据也复制到新表中,在行所有数据复制完成之后,把新表命名成原表,并把原来的表删除掉。把原来一个 DDL 操作,分解成多个小的批次进行。 3.

    49410

    面试官:你对MySQL高性能优化有什么规范建议?

    数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,...禁止在表中建立预留字段 预留字段的命名很难做到见名识义。 预留字段无法确认存储的数据类型,所以无法选择合适的类型。 对预留字段类型的修改,会对表进行锁定。 8....在Mysql中,对于同一个SQL多关联(join)一个表,就会多分配一个关联缓存,如果在一个SQL中关联的表越多,所占用的内存也就越大。...pt-online-schema-change它会首先建立一个与原表结构相同的新表,并且在新表上进行表结构的修改,然后再把原表中的数据复制到新表中,并在原表中增加一些触发器。...把原表中新增的数据也复制到新表中,在行所有数据复制完成之后,把新表命名成原表,并把原来的表删除掉。把原来一个DDL操作,分解成多个小的批次进行。

    50210

    Mysql高性能优化规范建议

    数据库命令规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意,...禁止在表中建立预留字段 预留字段的命名很难做到见名识义。 预留字段无法确认存储的数据类型,所以无法选择合适的类型。 对预留字段类型的修改,会对表进行锁定。 8....在Mysql中,对于同一个SQL多关联(join)一个表,就会多分配一个关联缓存,如果在一个SQL中关联的表越多,所占用的内存也就越大。...pt-online-schema-change它会首先建立一个与原表结构相同的新表,并且在新表上进行表结构的修改,然后再把原表中的数据复制到新表中,并在原表中增加一些触发器。...把原表中新增的数据也复制到新表中,在行所有数据复制完成之后,把新表命名成原表,并把原来的表删除掉。把原来一个DDL操作,分解成多个小的批次进行。

    1.1K30

    MySQL高性能优化规范建议,值得收藏

    MySQL 保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来)•数据库对象的命名要能做到见名识意,并且最后不要超过 32 个字符•临时库表必须以 tmp_为前缀并以日期为后缀,备份表必须以...禁止在表中建立预留字段 预留字段的命名很难做到见名识义。 预留字段无法确认存储的数据类型,所以无法选择合适的类型。 对预留字段类型的修改,会对表进行锁定。 8....在 MySQL 中,对于同一个 SQL 多关联(join)一个表,就会多分配一个关联缓存,如果在一个 SQL 中关联的表越多,所占用的内存也就越大。...pt-online-schema-change 它会首先建立一个与原表结构相同的新表,并且在新表上进行表结构的修改,然后再把原表中的数据复制到新表中,并在原表中增加一些触发器。...把原表中新增的数据也复制到新表中,在行所有数据复制完成之后,把新表命名成原表,并把原来的表删除掉。把原来一个 DDL 操作,分解成多个小的批次进行。 3.

    1.2K41

    史上最全的MySQL高性能优化规范建议

    1、数据库命名规范 所有数据库对象名称必须使用小写字母并用下划线分割 所有数据库对象名称禁止使用mysql保留关键字(如果表名中包含关键字查询时,需要将其用单引号括起来) 数据库对象的命名要能做到见名识意...经常一起使用的列放到一个表中(避免更多的关联操作)。 7)禁止在表中建立预留字段 预留字段的命名很难做到见名识义 预留字段无法确认存储的数据类型,所以无法选择合适的类型。...在Mysql中,对于同一个SQL多关联(join)一个表,就会多分配一个关联缓存,如果在一个SQL中关联的表越多,所占用的内存也就越大。...pt-online-schema-change它会首先建立一个与原表结构相同的新表,并且在新表上进行表结构的修改,然后再把原表中的数据复制到新表中,并在原表中增加一些触发器把原表中新增的数据也复制到新表中...,在把所有数据复制完成之后,把新表命名成原表,并把原来的表删除掉。

    1.6K20
    领券