快速修改MySQL某张表的表结构--摘录自《MySQL管理之道》 ALTER TABLE 表名 MODIFY 列名 数据类型; 这个命令可以修改表结构 此外,也可以如下方法修改表结构: 先创建一张表,如下...> create table t1 (id int, name varchar(5), rmb decimal(9,1)); 如果要修改name列为varchar(10)的,... | | +-------+--------------+------+-----+---------+-------+ 3 rows in set (0.00 sec) 2、创建临时表,...> flush tables with read lock; 先锁住表,放在表被打开,以免数据丢失。 ...` decimal(9,1) DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8 1 row in set (0.00 sec) 可以看到name列的varchar
个人简介:Java领域新星创作者;阿里云技术博主、星级博主、专家博主;正在Java学习的路上摸爬滚打,记录学习的过程~ 个人主页:.29.的博客 学习社区:进去逛一逛~ 数据库表的创建、查询、...数据类型 数据库表中的数据类型: 数值类型: TINYINT:小整数 SMALLINT:大整数 MEDIUMINT:大整数,范围大于SMALLINT INT/INTEGER:大整数,范围大于MEDIUMINT...DDL - 表操作 DDL-表操作: 查询表信息 ①查询当前数据库所有表 SHOW TABLES; ②查询表结构 DESC 表名; ③查询指定表的建表语句 SHOW CREATE TABLE 表名; 创建表操作...; /* 案例:设计一张员工表,需求如下 1.编号(纯数字) 2.员工工号(字符串,长度不超过10) 3.员工姓名(字符串,长度不超过10) 4.性别(男/女。...] 表名; -- 演示 -- 删除名为aaa的表 -- 执行时,如果aaa表不存在,报错: -- 错误代码: 1051 Unknown table '表名' DROP TABLE aaa; -- 使用关键字
查询某张表的列的备注 select COLUMN_NAME 列名, COMMENTS 注释 from user_col_comments where table_name = '表名' 返回结果: 列名...查询某张表的列定义 select COLUMN_NAME 列名, DATA_TYPE 类型, DATA_LENGTH 长度 from USER_TAB_COLUMNS where TABLE_NAME...= '表名'; 返回结果: 列名 类型 长度 CREATE_TIME DATE 7 ... ... ...
文章背景:在操作Excel文件时,有时需要判断指定的工作表是否存在,根据判断结果进行后续操作。下面提供两种自定义函数。...(1)遍历法 Function IsExistsSheetName1(strPath As String, SheetName As String) As Boolean '如果目标工作表存在...,返回TRUE;否则,返回FALSE 'strPath:指定文件的全路径(Full path) Dim tempSheet As Worksheet Workbooks.Open...,返回TRUE;否则,返回FALSE 'strPath:指定文件的全路径(Full path) Dim tempSheet As Worksheet Workbooks.Open...ActiveWorkbook.Close SaveChanges:=False End Function 注意:需要确保指定路径(strPath)的文件已存在
mysql 根据一张表数据更新另一张表 sql示例 update a ,b set a.name = b.name where a.id = b.id 一)在同一个数据库服务器上面进行数据表间的数据导入导出...这时就要使用到数据库(表)的导出,导入。即将远程的数据库(表)导出到本地文件中,然后再将该数据库(表)导入(还原)到本地数据库中。...导入数据库(表) (1)导入数据库 在本地数据库中创建相对应导出的数据库mydb同名的数据库: mysql> create database mydb; 然后退出数据库,再使用以下的 命令导入数据库文件...是远程数据库mydb导出文件的本地存放位置 (2)导入数据表 在本地数据库中创建相对应导出的数据库mydb同名的数据库: mysql> create database mydb; 然后在mysql...(表)的导入、导出过程中,视数据库(表)的大小,需要一定的时间开销,请耐性等候…… 四)导入、导出数据表中的数据 1.
Mysql清空表(truncate)与删除表中数据(delete)的区别 为某基于wordpress搭建的博客长久未除草,某天升级的时候发现已经被插入了几万条垃圾留言,如果一条条删除那可真是累人的活。...遂考虑直接进入mysql直接清空表或者删除表中数据。 本文记录一下这2种操作模式的区别,目标对象是表wp_comments,里面的所有留言均是垃圾留言,均可删除。...然后便有了以下2种方式(进入mysql操作界面后): truncate table wp_comments; delete * from wp_comments; 其中truncate操作中的table...这两者都是将wp_comments表中数据清空,不过也是有区别的,如下: truncate是整体删除(速度较快), delete是逐条删除(速度较慢)。...而delete删除以后,Identity依旧是接着被删除的最近的那一条记录ID加1后进行记录。 如果只需删除表中的部分记录,只能使用DELETE语句配合where条件。
MySQL里面直接对大表执行drop table删除有可能导致mysql hang住。必须使用些特殊的方法。 先搞一个大表出来,如下图: ? 可以看到t2表的ibd大小为2.7GB了 ?...创建一个硬链接的好处就是: 硬链接就是增加了对文件的引用,只有对磁盘上文件的引用完全没有了的话,这个文件才能是删除的。...我们对t2.ibd 建立硬链接后,当我们执行drop table t2; 的时候,实际上只是删除了对t2.ibd的一个文件引用,我们t2.ibd_hdlk对物理文件的引用还是存在的,就不会执行OS级别的删除操作...这种对线上mysql的影响降到很低。...这个小文件我们直接使用rm删除即可。 ? 这样就彻底删除掉这个t2大表了。
需求 有时候又删除大表的需求, 一般直接drop就行, 但有时候会有IO的问题. 什么叫大表呢?...其实也可以算一种, 毕竟都是truncate (os) 本环境两张表, 一样的数据, 都是35GB (15000W行) 方案1: 在 os 层面创建硬链接 ln /data/mysql_3306/mysqldata.../db1/sbtest1.ibd /data/mysql_3306/mysqldata/db1/sbtest1.ibd.rm 然后在mysql上删除sbtest1表 drop table sbtest1...然后删除表 mysql> flush table sbtest2 for export; shell> mv /data/mysql_3306/mysqldata/db1/sbtest2.ibd /data...100MB. mysql的表也尽量不要整这么大, 日志表之类的, 可以按时间分个区.
-- ============================================= -- Author: ...-- Create date: -- Description: -- =========================================...') and OBJECTPROPERTY(id,N''IsUserTable'')=1'; print @sql exec(@sql) END GO c#调用这个存储过程,返回1则存在,返回0则表不存在
背景在MySQL中有大表需要清理,该表超过100GB,不敢直接delete或者truncate、drop,怕影响业务。...truncatetruncate命令清除整个表的数据,需要执行人有drop权限。truncate相当于把表drop掉然后重新创建一张新表。truncate成功后,不会返回具体删除的数据行数。...truncate会清空表中的所有行,但表结构及其约束、索引等保持不变;drop会删除表的结构及其所依赖的约束、索引等。truncate会重置表的自增值;delete不会。...常见的大表删除方式对于大表的场景,常见的做法:小批量、分批删除;由于直接使用delete,是逐步删除,直接delete不带where条件肯定是不科学的。...建议数据量小的时候,清空表数据,使用truncate命令,删除表可直接drop数据量大的时候,使用创建硬链接的方式,drop table后再逐步删除文件;使用TDSQL的话,打开异步删除配置参数,直接drop
表数据如下 查看用户名相同的记录 select * from user where username in (select username from user group by username...删除用户名和手机号都相同的重复记录 DELETE from user where (username,phone) -- 注意:此处一定要加括号,当成联合字段来处理 IN ( --...HAVING COUNT(1) > 1 ); 上述语句看着是不是应该正常能执行删除掉用户名和手机号都相同的重复记录只保留id最小的那一条。...实际执行会报如下错误: 1093 - You can’t specify target table ‘user’ for update in FROM clause 含义:不能在同一表中查询的数据作为同一表的更新数据...; INSERT INTO `user`(`id`, `username`, `phone`, `age`) VALUES (1, '我是主数据库的zjq', '13666666666', 18);
恢复slave上的某几张表的方法 摘录自《MySQL管理之道》Page126 有时候,slave上只是几张表有些问题,如果从master上dump一份进行恢复的话,对于体积很大的数据库,则要花费很长的时间...,长时间的持锁还容易影响到业务。...下面介绍一种方法,恢复test_DB下的3张表tb1、tb2、tb3,操作如下: 1、在slave上先停止复制 > stop slave; 2、在主库上导出3张需要恢复的表,并记录下同步的binlog...mnysql-bin.000010',master_LOG_POS=10020;” 4、做change master to操作: > start slave until master_LOG_FILE='mysql-bin...=1; start slave; 5、把/root/tb123.sql复制到slave机器上,并在slave机器上导入/root/tb123.sql # mysql -uroot -proot test_DB
一.简介 源码地址 日期:2018/4/12 介绍:工具用于安全删除MySQL表,对于一些特定场景可能有用 应用场景:大批删除不走索引但是有主键的场景[可以是单列索引,也可是多列索引] 实现思路:根据where...中文 注意:必须有主键或者非空唯一索引 1.下载 git clone https://gitee.com/mo-shan/safe_delete.git cd safe_delete 2.配置,将这里的mysql_path...改成mysql工具的绝对路径,否则可能会因版本太低导致错误 ed -i 's#^mysql_path=....*#mysql_path=\"/mysqlbinlog_path\"#g' bin/safe_delete 将这里的safe_delete_path改成safe_delete的家目录的绝对路径 sed
删除表相关的磁盘文件 二、创建硬链接 三、删除表 四、删除文件释放空间 参考: ---- 在一个高负载的生产数据库上删除大表需要一些技巧,倘若直接drop table,将产生大量磁盘I/...1. buffer pool清除 删除表时,MySQL会将表在buffer pool中对应的页面清除,这个过程中会对buffer pool上一个全局排它锁。...如果buffer pool很大,或者表有很多脏页面需要被清除,则持有mutex的时间会相对较长,导致其它事务在用到相应buffer pool实例时被阻塞,从而影响整个数据库性能。...可以使用以下脚本对一个数据库内的所有表创建硬链接: # MySQL数据目录 datadir=`mysql -uroot -p123456 -S /data/mysqldata/mysql.sock -e...{ibd,frm} | awk '{print "ln "$0" "$0".h"}' | bash 三、删除表 drop table t1; MySQL的drop table操作会删除系统表中
前言 线上有一个表,大小为24G左右,没有什么重要的数据,却一直没有优化,导致业务无法进行,在此环境上,所以我们开始了删除之路 步骤 复制表 我这里使用Navicat工具直接复制表,选择仅结构即可。...创建硬链接 如果不知道自己的存储位置,可使用show variables like "datadir";查看自己的数据存储位置。...ln instruction.frm instruction.frm.bak ln instruction.ibd instruction.ibd.bak 删除表 DROP TABLE "表格名";...24G的数据删除大概用了15秒左右 修改表名 将我们刚才复制的表,表名修改为线上正常使用的表名即可。...删除物理文件 切记大的物理文件不可直接删除,直接操作会导致磁盘IO和CPU利用率升高,影响线上业务可使用truncate来进行删除操作。
一.数据表重命名 RENAME TABLE asus To tb_asus; 总结语法: RENAME TABLE 数据表名 1 To 数据表名 2 --多个表之间以逗号“,” 二.数据表复制 CREATE...TABLE tb_user LIKE tb_asus; --将复制该表的列名,数据类型空指定和索引都将被复制,但表的内容不会被复制。...CREATE TABLE tb_user AS SELECT*FROM tb_asus; --将复制该表的列名,数据类型空指定和索引,以及表的内容都将被复制。...--若使用第二种方法复制,会发现信新复制出来的表并不包括原表中设置的主键,自动编号等,如果想要和原表完全一样,应使用下面语句。...CREATE TABLE tb_user SELECT * FROM tb_asus; 三.数据表删除 DROP TABLE [IF NOT EXISTS] 数据表名; --删除多个表用逗号隔开 Python
MySQL 删除数据表MySQL中删除数据表是非常容易操作的,但是你在进行删除表操作时要非常小心,因为执行删除命令后所有数据都会消失。...语法以下为删除MySQL数据表的通用语法:DROP TABLE table_name ;----在命令提示窗口中删除数据表在mysql>命令提示窗口中删除数据表SQL语句为DROP TABLE:实例以下实例删除了数据表...规定要使用的 MySQL 连接。query必需,规定查询字符串。resultmode可选。一个常量。...可以是下列值中的任意一个: * MYSQLI_USE_RESULT(如果需要检索大量数据,请使用这个) * MYSQLI_STORE_RESULT(默认)实例以下实例使用了PHP脚本删除数据表 kxdang_tbl...:删除数据库<?
MySQL中删除数据表是非常容易操作的,但是你在进行删除表操作时要非常小心,因为执行删除命令后所有数据都会消失。...语法 以下为删除MySQL数据表的通用语法: DROP TABLE table_name ; ---- 在命令提示窗口中删除数据表 在mysql>命令提示窗口中删除数据表SQL语句为 DROP TABLE...使用 mysqli_query 函数来删除 MySQL 数据表。...规定要使用的 MySQL 连接。 query 必需,规定查询字符串。 resultmode 可选。一个常量。...,请使用这个) MYSQLI_STORE_RESULT(默认) 实例 以下实例使用了PHP脚本删除数据表 runoob_tbl: 删除数据库 <?
//查询表的主键约束名 select * from user_constraints e where e.table_name='表名';--输入 //查询所有引用到该主键的记录 select b.table_name
3.帮助手册 bash bin/safe_delete -h 4.使用演示 查看表,删除手机号是“00175731528296189904”的数据,手机号不是索引字段 mysql(test@localhost...USING BTREE ) ENGINE=InnoDB AUTO_INCREMENT=5000001 DEFAULT CHARSET=utf8 1 row in set (0.03 sec) test的功能...type --where="phone='00175731528296189904'" --user=test --host=127.0.0.1 --port=3311 --type=test get的功能...type --where="phone='00175731528296189904'" --user=test --host=127.0.0.1 --port=3311 --type=get delete的功能
领取专属 10元无门槛券
手把手带您无忧上云