MySQL使用技巧: 如何查看mysql正在执行的SQL语句 背景: 最近项目开发用到MySQL,想要查看后台执行的sql语句,立马google得知、可以使用 show processlist; 命令来解决...,通过里面输出结果的字段解释中可以分析执行了的sql语句类型,但发现不太适合一般的初级使用者,而通过日志文件查看sql语句是最直接的方法。...使用方法: 1:首先你需要创建一个日志文件log.txt ,例如如我直接保存在mysql目录下的data目录中间, 2:在 mysql的配置文件 my.ini 中最后添加 log=d:/mysql/data...补充: 我们也可以使用命令 show processlist; 来查看; mysql,输入show processlist; 如果有SUPER权限,则可以看到全部的线程,否则,只能看到自己发起的线程(这是指...db列,显示这个进 程目前连接的是哪个数据库。 command列,显示当前连接的执行的命令,一般就是休眠(sleep),查询(query),连接(connect)。
当前运行的所有事务,已经完成的是查不到的 select * from information_schema.innodb_trx; 当前出现的锁 # 当前的锁 Mysql8.0 之前使用:select...* from information_schema.innodb_locks; Mysql8.0 使用:select * from performance_schema.data_locks; #...锁等待的对应关系 Mysql8.0 之前使用:select * from information_schema.innodb_lock_waits; Mysql8.0 使用:select * from...performance_schema.data_lock_waits; 锁等待的对应关系 # Mysql8.0 之前使用: select * from information_schema.innodb_lock_waits...; # Mysql8.0 使用: select * from performance_schema.data_lock_waits; 查看锁的情况 附有字段说明 show status like 'innodb_row_lock
, 1 warning (0.00 sec) 二、查看锁的情况 mysql> show status like 'innodb_row_lock_%'; +-----------------------...Sleep:线程正在等待客户端向其发送新的语句。 ...SHOW WARNINGS命令:可以查看MySQL优化器优化后的SQL语句。 EXPLAIN PARTITIONS命令:显示SQL语句的带有分区表信息的查询执行计划。 ...五、数据库的一些默认设置 # 查看数据库默认存储引擎 mysql> show engines; +--------------------+---------+-----------------...-----------------------------------+--------------+------+------------+ 9 rows in set (0.00 sec) # 查看当前数据库默认隔离级别
一、使用 netstat 检查端口 netstat 是一个命令行工具,可以提供有关网络连接的信息。...要列出正在侦听的所有 TCP 或 UDP 端口,包括使用端口和套接字状态的服务,请使用以下命令:netstat -tunlp 此命令中使用的选项具有以下含义: -t – 显示 TCP 端口。...使用示例:ss -tunlp 三、使用 lsof 检查端口 lsof 是一个功能强大的命令行实用程序,它提供有关进程打开的文件的信息。...要使用 lsof 获取所有侦听 TCP 端口的列表:lsof -nP -iTCP -sTCP:LISTEN 使用的选项如下:-n – 不要将端口号转换为端口名称。...使用示例: 要查找正在侦听特定端口(例如 3306)的进程,请使用以下命令:sudo lsof -nP -iTCP:3306 -sTCP:LISTEN 至此关于Linux系统查看正在使用的端口的教程已经分享完毕
端口可以认为是设备与外界通讯交流的出口,就好像是门牌号一样,那么在Linux系统中如何查看正在使用的端口?下面为大家分享一下Linux系统查看正在使用端口的具体方法。...要列出正在侦听的所有 TCP 或 UDP 端口,包括使用端口和套接字状态的服务,请使用以下命令:netstat -tunlp 此命令中使用的选项具有以下含义: -t – 显示 TCP 端口。...使用示例:ss -tunlp 三、使用 lsof 检查端口 lsof 是一个功能强大的命令行实用程序,它提供有关进程打开的文件的信息。...要使用 lsof 获取所有侦听 TCP 端口的列表:lsof -nP -iTCP -sTCP:LISTEN 使用的选项如下:-n – 不要将端口号转换为端口名称。...使用示例: 要查找正在侦听特定端口(例如 3306)的进程,请使用以下命令:sudo lsof -nP -iTCP:3306 -sTCP:LISTEN 至此关于Linux系统查看正在使用的端口的教程已经分享完毕
– 1.切换 USE information_schema; – 2.查看数据库使用大小 SELECT concat( round( sum(data_length / 1024 / 1024...), 2 ), 'MB' ) AS DATA FROM TABLES WHERE table_schema = 'user_server'; – 3.查看表使用大小 SELECT
2017-10-16 回答 一.错误日志 错误日志在mysql数据库中很重要,它记录着mysqld启动和停止,以及服务器在运行过程中发生的任何错误的相关信息。...note:由于log日志记录了数据库所有操作,对于访问频繁的系统,此种日志会造成性能影响,建议关闭。 1.配置信息 –log=[file-name]用来指定错误日志存放的位置。...var/lib/mysql/query_log.log …… 2.读取查询日志 查询日志是纯文本格可,可以使用os文本读取工具直接打开查看。...note:慢查询日志对于我们发现性能有问题的sql有很帮助,建议使用并经常分析 1.配置信息 –log-slow-queries=[file-name]用来指定错误日志存放的位置。...查看从某一段时间到某一段时间的日志 mysqlbinlog –start-datetime=’2008-01-19 00:00:00′ –stop-datetime=’2008-01-30 00:00:
前言 为了计算一些后面的扩展,所以看下当前业务数据的存储 步骤 所有的信息都存放在information_schema这个库里面,我们可以通过查询这个库中的数据来找到我们需要的数据。...查看所有库的数据和索引大小 select table_schema, concat(truncate(sum(data_length)/1024/1024/1024,2),' GB') as data_size
二、查询表中列的注释信息 select * from information_schema.columns where table_schema = ‘db’ #表所在数据库 and table_name...where table_schema =’db’ and table_name = ‘tablename’ ; 四、#查看表的注释 select table_name,table_comment...from information_schema.tables where table_schema = ‘db’ and table_name =’tablename’ ps:二~四是在元数据表中查看...,我在实际操作中,常常不灵光,不知为什么,有了解的大侠请留印。...五、查看表生成的DDL show create table table_name; 这个命令虽然显示起来不是太容易看, 这个不是问题可以用\G来结尾,使得结果容易阅读;该命令把创建表的DDL显示出来,
大家好,又见面了,我是你们的朋友全栈君。 CPUQuota=value 该参数表示服务可以获取的最大 CPU 时间,value 为百分数形式,高于 100% 表示可使用 1 核以上的 CPU。...MemoryLimit=value 该参数表示服务可以使用的最大内存量,value 可以使用 K, M, G, T 等后缀表示值的大小。...事务的4种隔离级别 READ UNCOMMITTED 未提交读,可以读取未提交的数据。...REPEATABLE READ 可重复读,事务中的一致性读取读取的是事务第一次读取所建立的快照。...数据范围全集组成 SQL 语句根据条件判断不需要扫描的数据范围(不加锁); SQL 语句根据条件扫描到的可能需要加锁的数据范围; 以单个数据范围为例,数据范围全集包含:(数据范围不一定是连续的值,也可能是间隔的值组成
今天进行数据库备份恢复 一直卡住 找了一下 公司另外一个部门的方神提供了一个方法连查看 具体在做什么操作: 2....方法 查看一下任务信息 SELECT owner_name, job_name, operation, job_mode, state, attached_sessions FROM dba_datapump_jobs
1.查看当前会话隔离级别 select @@tx_isolation; 2.查看系统当前隔离级别 select @@global.tx_isolation; 3.设置当前会话隔离级别 set...2.read committed 读取提交的数据。但是,可能多次读取的数据结果不一致(不可重复读,幻读)。用读写的观点就是:读取的行数据,可以写。...3.repeatable read(MySQL默认隔离级别) 可以重复读取,但有幻读。读写观点:读取的数据行不可写,但是可以往表中新增数据。在MySQL中,其他事务新增的数据,看不到,不会产生幻读。...想要理解这四个级别,还需要知道三种不讨人喜欢的事情: dirty reads:脏读,就是说事务A未提交的数据被事务B读走,如果事务A失败回滚,将导致B所读取的数据是错误的。...但是不可重复读的不一致是因为它所要取的数据集被改变了,而幻读所要读的数据不一致却不是他所要读的数据改变,而是它的条件数据集改变。
1、查看数据库表数量 SELECT count(TABLE_NAME) FROM information_schema.TABLES WHERE TABLE_SCHEMA=’dbname’; select
要想知道每个数据库的大小的话,步骤如下: 1、进入information_schema 数据库(存放了其他的数据库的信息) use information_schema; 2、查询所有数据的大小: select...concat(round(sum(data_length/1024/1024),2),‘MB’) as data from tables; 3、查看指定数据库的大小: 比如查看数据库home的大小 select...concat(round(sum(data_length/1024/1024),2),‘MB’) as data from tables where table_schema=‘home’; 4、查看指定数据库的某个表的大小...比如查看数据库home中 members 表的大小 select concat(round(sum(data_length/1024/1024),2),‘MB’) as data from tables
有时候在我们开发的过程中并不一定记得数据库的安装路径。...比如要查看MySQL 数据库的安装目录在哪里: 我们可以通过mysql命令查看mysql的安装路径: # 以下两个sql任意一个可查询 select @@basedir as basePath from...dual ; show variables like '%basedir%'; 上面可以看到基础的安装路径,查看数据库data的路径怎么看,很简单,把上面的参数变量换成datadir即可: # 以下查询任意一个均可...,那么朋友会问,如果也不知道登录mysql 的账户密码,那又如何在查看mysql路径呢?...这种是不是很繁琐,还要更简单的 方法二: 查看mysql的安装信息: ps -ef | grep mysql 红色标记的可以看出具体路径。
很多时候网站打开速度变慢,为了定位是否为数据库导致的,我们需要知道在访问网站的同时,站点执行了哪些SQL,每条SQL耗时多长。 为此,查看数据库日志是最直接的。...一般情况下,数据库日志默认是关闭的,因此需要先激活日志功能: 1....使用root用户登陆到数据库后,检查“数据库日志”是否开启 SHOW VARIABLES LIKE 'general%'; # 这份日志会保存到数据库的安装目录, Centos7默认的目录是 /var...无需重启数据库,直接刷新站点,发现 VM_211_224_centos.log 日志有内容,VM_211_224_centos-slow.log日志无内容(当然这是针对我的情况而言,mysql/mariadb...但是这里可以通过tail -f实时直播日志的打印,以判断执行哪些SQL时会有停顿: tail -10f /var/lib/mysql/VM_211_224_centos.log 刷新网站后,就能通过日志发现
MySQL 查看数据库表详情 查看所有数据库容量大小 select table_schema as '数据库', sum(table_rows) as '记录数', sum(truncate(data_length...这是因为 delete 操作并不会真的把数据删除,mysql 实际上只是给删除的数据打了个标记,标记为删除,因此你使用 delete 删除表中的数据,表文件在磁盘上所占空间不会变小,我们这里暂且称之为假删除...对于这种情况,可以使用以下命令来重新利用未使用的空间,解决数据空洞问题。...重建操作能更新索引统计数据并释放成簇索引中的未使用的空间。注意:在 optimize table 运行过程中,MySQL 会锁定表,所以要在空闲时段执行。...查看前后效果可以使用 show table status 命令,返回结果中的 data_free 即为空洞所占据的存储空间。
在MySQL数据库中,可以通过执行SQL查询来检查数据库的默认字符集,也可以查看特定数据库、表或列的字符集。...查看特定数据库的字符集: sql SELECT DEFAULT_CHARACTER_SET_NAME, DEFAULT_COLLATION_NAME FROM information_schema.SCHEMATA...查看特定表的字符集: sql SHOW TABLE STATUS LIKE 'your_table_name'; 这会显示包括表的字符集在内的一系列属性。...查看当前连接的字符集设置: sql SHOW VARIABLES LIKE 'character_set%'; SHOW VARIABLES LIKE 'collation%'; 这些查询会返回当前数据库连接的字符集和校对设置...、 通过这些查询,可以了解到MySQL中的字符集配置情况。如果需要改变字符集,可以使用 ALTER 语句来更改数据库、表或列的字符集。
领取专属 10元无门槛券
手把手带您无忧上云