前言 为了计算一些后面的扩展,所以看下当前业务数据的存储 步骤 所有的信息都存放在information_schema这个库里面,我们可以通过查询这个库中的数据来找到我们需要的数据。...查看所有库的数据和索引大小 select table_schema, concat(truncate(sum(data_length)/1024/1024/1024,2),' GB') as data_size
本篇主要介绍如何使用pymysql操作数据库,下面直接进入正文 1.查询数据 # coding: utf-8 # author: hmk import pymysql.cursors # 连接数据库...conn = pymysql.connect(host='localhost', # 数据库地址 port=3306, #端口默认是3306,不写这个也可以...,如果不是3306则需要在此声明 user='root', # 数据库的登录用户 password='123456...', # 密码 db='test', # 要操作额数据库 charset='utf8') # 创建一个游标...', # 密码 db='test', # 要操作额数据库 charset='utf8') # 创建一个游标
已提交读,对于锁定读(select with for update 或者 for share)、update 和 delete 语句,InnoDB 仅锁定索引记录,而不锁定它们之间的间隙,因此允许在锁定的记录旁边自由插入新记录...REPEATABLE READ 可重复读,事务中的一致性读取读取的是事务第一次读取所建立的快照。...SERIALIZABLE 序列化在了解了 4 种隔离级别的需求后,在采用锁控制隔离级别的基础上,我们需要了解加锁的对象(数据本身&间隙),以及了解整个数据范围的全集组成。
1.查看当前会话隔离级别 select @@tx_isolation; 2.查看系统当前隔离级别 select @@global.tx_isolation; 3.设置当前会话隔离级别 set...3.repeatable read(MySQL默认隔离级别) 可以重复读取,但有幻读。读写观点:读取的数据行不可写,但是可以往表中新增数据。在MySQL中,其他事务新增的数据,看不到,不会产生幻读。...像java中的锁,写数据必须等待另一个事务结束。...non-repeatable reads:不可重复读,就是说事务A中两处读取数据,第一次读时是100,然后事务B把值改成了200,事务A再读一次,结果就发现值变了,造成A事务数据混乱。...phantom read:幻读,和不可重复读相似,也是同一个事务中多次读不一致的问题。
有时候在我们开发的过程中并不一定记得数据库的安装路径。...比如要查看MySQL 数据库的安装目录在哪里: 我们可以通过mysql命令查看mysql的安装路径: # 以下两个sql任意一个可查询 select @@basedir as basePath from...dual ; show variables like '%basedir%'; 上面可以看到基础的安装路径,查看数据库data的路径怎么看,很简单,把上面的参数变量换成datadir即可: # 以下查询任意一个均可...,那么朋友会问,如果也不知道登录mysql 的账户密码,那又如何在查看mysql路径呢?...方法一: 1:查询运行文件所在路径 which mysql 然后可通过 /usr/bin/mysql -u账号 -p密码 连接Mysql: 然后执行上面的任意一个MySQL查看安装路径。
要想知道每个数据库的大小的话,步骤如下: 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
1、查看数据库表数量 SELECT count(TABLE_NAME) FROM information_schema.TABLES WHERE TABLE_SCHEMA=’dbname’; select
MySQL 查看数据库表详情 查看所有数据库容量大小 select table_schema as '数据库', sum(table_rows) as '记录数', sum(truncate(data_length...mysql 中,使用 delete 命令删除数据后,会发现这张表的数据文件和索引文件却奇怪的没有变小。...这是因为 delete 操作并不会真的把数据删除,mysql 实际上只是给删除的数据打了个标记,标记为删除,因此你使用 delete 删除表中的数据,表文件在磁盘上所占空间不会变小,我们这里暂且称之为假删除...重建操作能更新索引统计数据并释放成簇索引中的未使用的空间。注意:在 optimize table 运行过程中,MySQL 会锁定表,所以要在空闲时段执行。...查看前后效果可以使用 show table status 命令,返回结果中的 data_free 即为空洞所占据的存储空间。
很多时候网站打开速度变慢,为了定位是否为数据库导致的,我们需要知道在访问网站的同时,站点执行了哪些SQL,每条SQL耗时多长。 为此,查看数据库日志是最直接的。...一般情况下,数据库日志默认是关闭的,因此需要先激活日志功能: 1....使用root用户登陆到数据库后,检查“数据库日志”是否开启 SHOW VARIABLES LIKE 'general%'; # 这份日志会保存到数据库的安装目录, Centos7默认的目录是 /var...无需重启数据库,直接刷新站点,发现 VM_211_224_centos.log 日志有内容,VM_211_224_centos-slow.log日志无内容(当然这是针对我的情况而言,mysql/mariadb...哪个SQL在执行的时候出现卡顿。
emoji就是我们聊天的时候的特殊表情, 是特殊字符(非字符串), unicode编码起始为 1F600 , 占用4个字节, 不同的终端显示可能不同,但是都是表示的同一个对象.比如 "草莓" 这个表情, 在浏览器上效果如下但是在微信上效果如下图片在...mysql workbench上效果如下(作为字符)图片emoji完整表情可以查看: https://unicode.org/emoji/charts/full-emoji-list.html在python...notebook你可以直接复制其它地方的表情到你的python代码print("")图片但是这样显然不方便, 所以我们可以调用emoji库来使用emojipip install emoji #安装emoji库查看下...cat)print(type(strawberry), type(cat))print(strawberry.encode(), cat.encode())图片发现emoji是字符串类型, 编码是4字节.在mysql...中存取emoji存通过上面发现emoji是字符串(这跟python语言有关, 实际上是字符), 占用4个字节, 所以得使用 utf8mb4 字符集(mysql低版本默认为utf8mb3)mysql建表如下
MySQL是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的RDBMS (Relational Database Management System,关系数据库管理系统)应用软件之一...MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。...6、查看MySQL服务器中root用户的初始密码 启动服务之后,MySQL会提供一个初始密码,我们需要这个密码进行登录以便后续修改密码: [root@bigdata uploads]# cat /var...; 在Centos7中默认不能修改简单密码,例如123456,但是可以通过设置进行修改,我们需要进入MySQL配置文件中加入配置就行: vi /etc/my.cnf 在文件最后加入:validate_password...四、基本使用方法 1、在Linux中启动MySQL数据库 [root@bigdata zhc]# systemctl start mysqld.service [root@bigdata zhc]# mysql
2017-10-16 回答 一.错误日志 错误日志在mysql数据库中很重要,它记录着mysqld启动和停止,以及服务器在运行过程中发生的任何错误的相关信息。...也可以将log-error配置到my.cnf文件中,这样就省去了每次在启动mysqld时都手工指定–log-error.例如: [mysql@test2]$ vi /etc/my.cnf # the mysql...也可以将log配置到my.cnf文件中,这样就省去了每次在启动mysqld时都手工指定–log.例如: # the mysql server [mysqld] …… #query-log log = /...var/lib/mysql/query_log.log …… 2.读取查询日志 查询日志是纯文本格可,可以使用os文本读取工具直接打开查看。...也可以将log-slow-queries配置到my.cnf文件中,这样就省去了每次在启动mysqld时都手工指定–log-slow-queries.例如: # the mysql server [mysqld
在 Linux 系统下经常要查看各种信息,命令蛮多的,而且又是久不久用一次的那种,记不下来,每回找又麻烦,干脆自己写一份在博客里面,自己找起来也方便。...#查看当前操作系统内核信息 cat /proc/cpuinfo #查看CPU信息 hostname #查看计算机名 lspci -tv...查看指定目录的大小 cat /proc/meminfo #查看内存信息 grep MemTotal /proc/meminfo #查看内存总量 grep MemFree /proc/meminfo...-t #查看挂接的分区状态 fdisk -l #查看所有分区 swapon -s #查看所有交换分区 hdparm -i /dev/hda...#查看磁盘参数(仅适用于IDE设备) dmesg | grep IDE #查看启动时IDE设备检测状况 网络 ifconfig #查看所有网络接口的属性
表数据如下 查看用户名相同的记录 select * from user where username in (select username from user group by username...HAVING count(*) >1); 查看用户名和手机号都相同的重复记录 select * from user where (username,phone) in (select username...,phone from user group by username,phone HAVING count(*) >1); 注意:where条件中(username,phone)的括号不能少不然会报错。...实际执行会报如下错误: 1093 - You can’t specify target table ‘user’ for update in FROM clause 含义:不能在同一表中查询的数据作为同一表的更新数据...ROW_FORMAT=DYNAMIC COMMENT='用户表'; INSERT INTO `user`(`id`, `username`, `phone`, `age`) VALUES (1, '我是主数据库的
简介 在之前的博客中已经配置过了,可以参考:https://www.xmmup.com/oracle-database-gatewaystoumingwangguandeanzhuanghepeizhi.html...#Oracle_lian_jie_daoMySQL Oracle使用DG4ODBC数据网关连接MySQL数据库,可以不用安装Gateways网关,其原理图如下: 从上图可知,Oracle连接MySQL需要涉及到如下组件...fs/cgroup \ --privileged=true lhrbest/oracle21c_ee_db_21.3.0.0 \ /usr/sbin/init -- 由于只读主目录特性,21c中的...spfile、pfile、密码文件默认在$ORACLE_BASE/dbs目录下,例如:/u01/app/oracle/dbs下。...lib64/libodbc.so HS_FDS_SUPPORT_STATISTICS=FALSE HS_LANGUAGE=AMERICAN_AMERICA.WE8ISO8859P15 EOF -- 查看是否开启只读主目录
本文主要从两个方面介绍tcpdump,首先是介绍下tcpdump的使用方式,然后介绍下tcpdump在mySQL数据库运维过程中具体实践,如果DBA能熟练的使用tcpdump,在运维工作中一定如虎添翼...监听本机3306端口的包,抓取完整包,并输出到tmp下 #tcpdump -s0 -vv port 3306 -w /tmp/`hostname`.pcap 四、在MySQL中的应用 案例一 第一个想写的是...案例二 在实际的运维过程中,有时业务反应慢,应用端也能看到SQL执行的时间比较长,但是数据库的慢日志中并没有抓到慢SQL。...通过整个TCP流的分析跟踪,基本可以判断出整个sql执行过程中慢在了数据库端,耗时约5.6s,整个过程中也没有丢包重传,也没有其他耗时的的情况发生,说明网络是正常的。...通过以上两个案例可以看出tcpdump在DBA实际工作中的重要性,不仅能诊断网络丢包、网络延迟的问题,还能协助DBA进行一些复杂数据库问题的诊断。
二、查询表中列的注释信息 select * from information_schema.columns where table_schema = ‘db’ #表所在数据库 and table_name...column_comment from information_schema.columns where table_schema =’db’ and table_name = ‘tablename’ ; 四、#查看表的注释...table_comment from information_schema.tables where table_schema = ‘db’ and table_name =’tablename’ ps:二~四是在元数据表中查看...,我在实际操作中,常常不灵光,不知为什么,有了解的大侠请留印。...五、查看表生成的DDL show create table table_name; 这个命令虽然显示起来不是太容易看, 这个不是问题可以用\G来结尾,使得结果容易阅读;该命令把创建表的DDL显示出来,
一、查看 一、查看MySQL数据库服务器和数据库MySQL字符集。 show variables like '%char%'; 二、查看MySQL数据表(table)的MySQL字符集。...show table status from sqlstudy_db like '%countries%'; 三、查看MySQL数据列(column)的MySQL字符集。...show full columns from countries; 二、修改 一、修改character_set_filesystem由binary转为utf-8 在my.ini配置文件中添加以下内容:...default-character-set=utf8 2、[mysqld]中加入 character-set-server=utf8 character-set-filesystem = utf8 3、重启mysql...服务 参考资料 mysql配置ini文件,加入[client]default-character-set=utf8,重启服务后不起作用 怎么查看mysql的数据库编码格式
MySQL数据库占用的空间、表记录的行数在MySQL的 information_schema 数据库。...在该库中有一个 TABLES 表,这个表主要字段分别是: TABLE_SCHEMA -- 数据库名 TABLE_NAME -- 表名 ENGINE -- 所使用的存储引擎 TABLES_ROWS --...记录数 DATA_LENGTH -- 数据大小 INDEX_LENGTH -- 索引大小 查询方法 查询某个数据库的空间大小 SELECT concat(round(sum(DATA_LENGTH/1024.../1024),2),'MB') as data FROM TABLES WHERE table_schema='要查询的数据库名字'; 查询某个数据库中某个表的空间大小 SELECT concat(round...(sum(DATA_LENGTH/1024/1024),2),'MB') as data FROM TABLES WHERE table_schema='要查询的数据库名字' and TABLE_NAME
SQL语句查看MySQL数据库大小 > SELECT table_schema "Database Name", sum( data_length + index_length ) / 1024 / 1024...0.09472656 | | information_schema | 0.15625000 | | jumpserver | 1.46875000 | | mysql...performance_schema | 0.00000000 | +--------------------+---------------------+ 6 rows in set (0.04 sec) 查看...MySQL表大小 例子:查看hellodb数据库,只显示出zabbix库中最大的10个表 > SELECT table_name AS "Tables",round(((data_length + index_length.../mysql-howto-find-the-database-and-table-size/
领取专属 10元无门槛券
手把手带您无忧上云