之前踩到过MySQL主键溢出的情况,通过prometheus监控起来了,具体见这篇MySQL主键溢出复盘 这次遇到的坑,更加的隐蔽。 是一个log表里面的一个int signed类型的列写满了。...快速的解决方法当然还是只能切新表来救急了,然后搬迁老表的部分历史数据到热表。 亡羊补牢,处理完故障后,赶紧写脚本把生产的其他表都捋一遍。...')') from information_schema.COLUMNS where TABLE_SCHEMA NOT IN ('information_schema','sys','test','mysql...NULL" ]]; then continue fi if [ ${ret} -lt 5000000 ] ; then echo "$line 剩余空间 ${ret}, 该表可用水位不足.../sql.log done # step2 将检查的内容打包发邮件(这里可能需要根据自己生产的情况改改) tar czf $(date +%F).tar.gz $(date +%F) sendemail
mysql的行的数据和体积等指标,我们可以通过定时任务脚本去采集information_schema.tables然后存到库里面。...最终效果如下: 看板对于的sql如下: select rds_name as "RDS实例", table_schema as "库名", table_name as "表名", table_rows...as "当前行数", total_size as "当前表总体积", max(table_rows) - min(table_rows) as "近7日增加行数" from rds_table_stats
mysql数据库基本语法 DDL操作 创建数据库 语法:create database 数据库名; 查看所有数据库 语法:show databases; 切换(使用)数据库 语法:use + 数据库名...; 创建一个表 语法:create table 表名( 字段名称1 字段类型, 字段名称2 字段类型, 字段名称3 字段类型, …… …… ); 查看数据库中所有表 语法: Show tables...; 查看表的结构 语法:desc 表名; 添加字段 语法:alter table 表名 add 字段名 字段类型 删除字段 语法:alter table 表名 drop 字段名 修改表名 语法:...rename table 旧的表名 to 新的表名 修改字段类型 语法:alter table 表名 modify 字段名 新的字段类型 字段重命名 语法:alter table 表名 change...,相当于先drop这张表在create这张表 约束 主键约束特点:唯一性,非空性 设置主键和自动增长 主键:在创建表时,在要设置为主键的字段后面 添加上主键(primary key) 自增长:在创建表时
上一篇文章使用了自定义的函数查找出来选择Math,或者选择Chinese或选择Japanese课程的学生。...mysql> select * from student_course where isInSearch(course, 'Math'); +------------------------------...为了解决这个问题,接下来会引入字段表,当然这一切都是因为最初的数据表设计不合理引起的。...这是简化了的字典表: mysql> select * from stu_dict; +--------------------------------------+-----------+------+...结果: mysql> SELECT id, `name`, getCourseNames(course) FROM student_course; +--------------------------
这是我工作遇到的问题,现在自己设计一个简化的类似场景,现实中这样的数据表设计可能有很多不合理的地方。...300) | YES | | NULL | | +--------+--------------+------+-----+---------+-------+ 这里只是记录学生的...ID,名字,还有选课的科目,科目有很多,在没有关联表的情况下,这么多科目只保存在一个字段中,用逗号隔开。...+--------------------------------------+--------+--------------------------------+ 那么如何查找到选择了Math课程的学生...想想使用关联表的时候,张三, 李四, 李五, 王小明这四个人都一条选择了Math这门课的记录,还有其他不是Math的记录。
今天分享的内容,是他在MySQL数据恢复上所做的尝试。 本文主要分享在没有备份的情况下,MySQL数据库如何恢复被删除的表。...包含两个主要的场景: 1、drop table后的恢复 2、truncate table后的恢复 正文: 我们都知道,MySQL Server都很多存储引擎,并不是每种都可以进行异常情况之下都恢复,比如...MySQL drop table 这里我们首先来测试innodb_file_per_table为off的情况,即表结构和数据存在同一个文件中。这里我分别测试了表存在主键和不存在主键的情况,供参考。...实际上我们也可以通过该工具来恢复表结构。 10加载数据到mysql server ? 11验证数据 ? 我们可以看到,被truncate 掉的数据被成功恢复了回来。...然而MySQL则有所不同,MySQL 默认会启动一些purge 进程来进行空间重用,这是MySQL 5.6的情况: ?
的水位线监控起来) IP_ADDR=$(/sbin/ip a|egrep '10.[0|1].[1-9]+.[1-9]+*' | awk '{print $2}'| cut -d '/' -f 1); mysql... WHERE c.extra = 'auto_increment' AND t.TABLE_SCHEMA NOT IN ('information_schema','mysql...', 'sys','test','performance_schema') AND t.auto_increment IS NOT NULL ; " 关于MySQL的采集脚本, 在prometheus...的mysql_exporter的源代码里面,有很多,大家感兴趣的可以自己去看一下代码。
作为产品DBA,经常被开发问,修改字段长度锁表吗?然后凭借"经验"给出回答:如果字段长度超过256个字符就会锁表。 现在看来回答错误 。...看看MySQL 官方文档 Extending VARCHAR column size The number of length bytes(字节) required by a VARCHAR column...如果修改字段的长度,导致字段的字节长度无法使用 1 byte表示,得使用2个byte才能表示,比如从 240 修改为 256 ,如果在默认字符集为utf8mb4的情况下,varchar(60) 修改为...当字段的字节数变动 跨越了256 则会锁表。 ?...关于MySQL online ddl 奉献一份 收藏多年的流程图, 以xmind 文件方式分享到百度云盘上,方便给位查看,可以直接访问原文直达百度云盘。 ?
MySQL索引失效情况 MySQL版本:8.0.17。...`%`也不会用到索引,就是like 'AA%',表中该列有很多AA开头的,应该是`mysql`自己会选择合适的方式,具体还得explain研究 数据类型出现隐式转换 explain select * from...=情况,我测试的是有的会用索引,有的不用,待考证,具体数据在文章末尾 #使用了索引 EXPLAIN SELECT * FROM demo WHERE telephone IS NULL; #使用了索引...自己认为不走索引比较快的情况,我水平不够,无法预判~~~ #test建表sql DROP TABLE IF EXISTS `test`; CREATE TABLE `test` ( `id` int...回表:demo表中telephone索引树上只记录了telephone数据列,我们查的是*,所以需要根据主键回表去查询全部列 #explain select * from demo left join
information_schema.innodb_lock_waits # 查看下autocommit的值 select @@autocommit; 1813 # 查看数据库的隔离级别: select @@tx_isolation; # 查看先当前库的线程情况
问题背景 前几天客户反馈,误删除了权限表,导致无法连接到实例中了,但是又没有备份,咨询要怎么去恢复; 针对上述的这种情况,下面给出具体的恢复方法; (备份重于一切!备份重于一切!...重要的事情说三遍) 环境说明: MYSQL 5.7版本 端口:3306和3309 说明:3309是故障的实例,3306是协助在没有备份的情况下做恢复 下面开始故障模拟和恢复: 1、查看一下目前user表中存在的用户...~]# mysql -u root -pXXXXXXXX -S /tmp/mysql3309.sock 第一种情况:误删除了user表,进程是启动的(只要用户不手动的去kill进程,进程是运行的) 第二种情况...:误删除了user表,进程被杀掉了,mysql服务处理停机状态,那么重启实例,肯定会报错(后面可以看到) 第一种情况:MYSQL服务进程是启动的 恢复方法: 从其他的运行好的数据库或官方文档找到mysql5.7...此时,user表恢复成功了,但是其他自建的用户就需要重新手动进行创建了,这就是不做备份的代价,出来混总是要还…… 第二种情况:MYSQL服务进程停掉了,无法重启成功 恢复方法: 如果mysql进程已经听掉了
TABLE_ROWS as recordSize from TABLES where table_schema='databaseName' and table_name='tableName'; 说明: MySQL...可查询数据库中每个表占用的空间、表记录的行数。...参考博客: 1.https://www.jianshu.com/p/8f086c98d591 mysql查询库大小,表行数,索引大小 2.https://www.cnblogs.com/mr-wuxiansheng.../p/7520628.html msyql round函数 3.https://blog.csdn.net/Saintyyu/article/details/100114372 为什么MySQL的索引要使用...4.https://www.cnblogs.com/guohu/p/10984278.html MySQL查询数据表的auto_increment(自增id)
下面几种情况下,索引是不会被使用的 (1)组合索引,查询时的条件列不是组合索引中的第一个列 例如 组合索引 (a,b),查询中使用了b作为查询条件,这时是不会用到索引的,如果用a作为查询条件,则会使用索引...查询字符串类型的字段时,如果值不用单引号引起来,则不使用索引 例如:a字段为字符串类型,并为索引,查询 where a=111,可以准确查询,但不会使用索引 where a='111',则会使用索引 值为数字类型时,mysql
1、列出当前在表缓存中打开的非临时表。...SHOW OPEN TABLES语法: SHOW OPEN TABLES [{FROM | IN} db_name] [LIKE 'pattern' | WHERE expr] mysql>...: Database: 数据库名称 Table: 表名 In_use: 表锁或锁请求的数量在表中。...例如,如果一个客户机使用锁表t1写的表获得一个锁,那么In_use将是1。如果另一个客户端问题锁表t1写,而表仍然锁定,客户端将阻塞等待锁,但是锁请求导致In_use为2。...'tb_employees' AND In_use > 0 参考:https://dev.mysql.com/doc/refman/5.6/en/show-open-tables.html
查看索引使用情况 2.2 mysql索引使用策略 2.3 mysql索引使用原则 ---- 1 mysql索引知识 1.1 B+Tree索引 在InnoDB中,表都是根据主键顺序以索引的形式存放的,这种存储方式的表称为索引组织表...很少的情况下,MySQL会选择优化不足的索引。...这种情况下,可以在SELECT语句中使用USE INDEX(indexname)来强制使用一个索引或者用IGNORE INDEX(indexname)来强制MySQL忽略索引。...在不损失精确性的情况下,长度越短越好。 ref:显示索引的哪一列被使用了,如果可能的话,是一个常数。 rows:MySQL认为必须检查的用来返回请求数据的行数。...这是const连接类型的特殊情况。 const: 表中的一个记录的最大值能够匹配这个查询(索引可以是主键或惟一索引)。
mysql中有一种机制是表锁定和行锁定,是为了保证数据的完整性。表锁定表示你们都不能对这张表进行操作,必须等我对表操作完才行。...当出现这种情况时,我们可以考虑分表或分区。...2、MySQL分表 分表是将一个大表按照一定的规则分解成多张具有独立存储空间的实体表,每个表都对应三个文件,MYD数据文件,.MYI索引文件,.frm表结构文件。...水平拆分原则,通常情况下,我们使用hash、取模等方式来进行表的拆分 比如一张有400W的用户表users,为提高其查询效率我们把其分成4张表users1,users2,users3,users4 通过用...#创建两个分表,表结构必须和上面完整的表结构一致 mysql> create table tb_member1 like member; mysql> create table tb_member2 like
MySQL中给一张千万甚至更大量级的表添加字段一直是比较头疼的问题,遇到此情况通常该如果处理?本文通过常见的三种场景进行案例说明。...02 场景1 直接添加字段 使用场景: 在系统不繁忙或者该表访问不多的情况下,如符合ONLINE DDL的情况下,可以直接添加。...-uroot -p'123456' --socket=/data/mysql3306/tmp/mysql.sock -e "select a....给表添加字段 mysql> alter table testdb.tb_add_columns add col3 int; ? 此时,访问正常。 ?...timeout exceeded; try restarting transaction 对于此情况,需等待系统不繁忙情况下添加,或者使用后续的在从库创建再进行主从切换。
public class DbConnect { public static Connection connection; public static String url = "jdbc:mysql...true"; public static Connection getConnection() { try { Class.forName("com.mysql.cj.jdbc.Driver...(SQLException e) { e.printStackTrace(); } return connection; } } 对应学生的实体类...body> 学生信息..."gridtable"> 修改学生信息
MySQL 的表有很多种,对表的操作主要是增删改查,今天来浅谈一下这些操作的底层代码和流程,以下以 tmp table为例子,为了更好的说明操作流程,该表没有建立 primary key。...1.首先创建一张 tmp table,第三个参数 is_virtual=false 代表这不是虚拟表,如果这个值设置为true那说明这是虚拟表,主要给存储过程建立临时表来存储参数的,这种虚拟表没有handler...: 1、初始化表:table->init_tmp_table 2、用传进来的create_field 信息创建表的列:make_field 3、创建表增删改查用的操作句柄:setup_tmp_table_handler...close_tmp_table(table); 关闭临时表 free_tmp_table(table); 释放表资源 6、打开表 open_tmp_table(TABLE *table...)这个打开表 以上是没有主键和索引的临时表操作,如果是有主键的表就涉及到索引的查询操作,这期不涉及这个知识点,下期再谈。
对用户来说,分区表是一个独立的逻辑表,但是底层由多个物理子表组成。实现分区的代码实际上是对一组底层表的句柄对象的封装。 mysql在创建表时使用PARTITION BY子句定义每个分区存放的数据。...分区表本身也有一些限制,下面是其中比较重要的几点: 1.一个表最多只能有1024个分区。 2.在mysql5.1中,分区表达式必须是整数,或者是返回整数的表达式。...在mysql5.5中,某些场景中可以直接使用列进行分区。 3.如果分区字段中有主键或者唯一索引的列,那么所有主键列和唯一索引列都必须包含进来。 4.分区表中无法使用外键约束。...update操作 当更新一条记录时,分区层先打开并锁住所有的底层表,mysql先确定需要更新的记录在哪个分区,然后取出数据并更新,再判断更新后的数据在哪个分区,最后对底层进行写入操作,并对原数据所在的底层表进行删除操作...虽然每个操作都有“先打开并锁住所有的底层表”,但这并不是说分区表在处理过程中是锁住全表的。如果存储引擎能够自己实现行级锁,例如innoDb,则会在分区层释放对应表锁。
领取专属 10元无门槛券
手把手带您无忧上云