查看mysql数据库总存储量已使用量还剩存储量 mysql查看库有多少数据量_表名

慕尼黑的夜晚无繁华

mysql 统计 表的数量:SELECT COUNT(1) FROM information_schema.TABLES WHERE TABLE_SCHEMA = '你的数据库';有时候需要查询MySQL数据库中各个表大小,该如何操作呢?MySQL中有一个名为 information_schema 的数据库,在该库中有一个 TABLES 表,这个表主要字段分别是:TABLE_SCHEMA : 数据库名TABLE_NAME:表名ENGINE:所使用的存储引擎TABLES_ROWS:记录数DATA_LENGTH:数据大小INDEX_LENGTH:索引大小use information_schema;SELECTTABLE_NAME,(DATA_LENGTH/1024/1024) as DataM ,(INDEX_LENGTH/1024/1024) as IndexM,((DATA_LENGTH+INDEX_LENGTH)/1024/1024) as AllM,TABLE_ROWSFROMTABLESWHERETABLE_SCHEMA = '你的数据库';MySQL的一些基础语句:行是记录 列是字段创建库CREATE DATABASE [IF NOT EXISTS] 数据库名 [参数[ 参数] [ 参数]...];参数:CHARACTER SET 码表名COLLATE 校对规则名, 详见文档10.10.1显示库SHOW DATABASES;显示数据库创建语句SHOW CREATE DATABASE 数据库名;修改库ALTER DATABASE 数据库名[ 参数[ 参数][ 参数]...];注意: 不能改数据库的名字删除库DROP DATABASE [IF EXISTS] 数据库名;操作表之前使用需要先确定使用哪个数据库USE 数据库名创建表CREATE TABLE 表名(列名 类型[,列名 类型][,列名 类型]...);查看所有表SHOW TABLES;查看表的创建语句SHOW CREATE TABLE 表名;显示表结构DESC 表名;修改表名RENAME TABLE 原表名 TO 新表名;修改字符集ALTER TABLE 表名 CHARACTER SET 字符集名;删除表DROP TABLE 表名;追加列ALTER TABLE 表名 ADD 列名 类型[,列名 类型][,列名 类型]...;修改列类型ALTER TABLE 表名 MODIFY 列名 类型[,列名 类型][,列名 类型]...;修改列ALTER TABLE 表名 CHANGE COLUMN 原列名 新列名 类型;删除列ALTER TABLE 表名 DROP 列名;插入语法:INSERT INTO 表名[(列名[,列名]...)] VALUES(值[,值]...);注意事项:插入值类型必须与对应列的数据类型一致数据不能超出长度插入值得为之必须与列名顺序一致字符和日期数据要放在单引号中插入空值使用null如果不指定插入哪一列, 就是插入所有列中文数据由于默认码表是utf8, 而cmd.exe的码表是gbk, 在插入中文数据的时候会报错, 所以我们需要修改客户端码表先查看系统变量: SHOW VARIABLES LIKE 'character%';修改客户端码表: SET character_set_client=gbk;修改输出数据的码表: SET character_set_results=gbk;修改语法UPDATE 表名 SET 列名=值[,列名=值]...[WHERE 条件语句];注意事项WHERE子句选择满足条件的行进行更新, 如果不写, 则更新所有行删除语法DELETE FROM 表名 [where 条件语句]注意事项如果不加where子句, 将删除表中所有记录delete只能用作删除行, 不能删除某一列的值, 需要用update在delete和update的时候需要注意表与表之间的关联关系删除表中所有数据可以使用: TRANCATE 表名, 这种方式会删除旧表重新创建, 在数据较多的时候使用备份数据库输入quit退出mysql, 在cmd.exe中输入:mysqldump –u用户名 –p密码 数据库名 > 文件名恢复数据库进入mysql.exe之后, 使用数据库之后source 文件名操作数据(查询)DISTINCT语法SELECT [DISTINCT] 列名[, 列名]... FROM 表名注意事项*可以替代列名, 表示所有列, 但是通常我们为了提高代码的可读性, 不使用*DISTINCT为过滤重复记录如果DISTINCT后面跟多列, 是过滤掉多列合并之后的重复列名表达式——语法SELECT 列名|表达式[,列名|表达式]... FROM 表名注意事项表达式只是显示时起作用, 不会改变数据库中的值AS——SELECT 列名 AS 别名 FROM 表名注意事项起别名时AS可以省略不会改变数据库中的值WHERE——语法SELECT 列名 FROM 表名 [WHERE 条件语句]WHERE子句中的运算符比较运算符>, =, <=, =, <>注意不等于和Java中不同, 是<>BETWEEN ... AND ...某一区间内的值, 从 ... 到 ...IN(列表)在列表之中, 例: in(1,2,3) 代表1或2或3LIKE(表达式)模糊查询, %代表多个字符, _代表单个字符IS NULL判断是否为NULL逻辑运算符AND &&与, 两边都为TRUE结果为TRUEOR ||或, 一边为TRUE结果就为TRUENOT !非, 将表达式结果取反ORDER BY——语法SELECT 列名 FROM 表名 ORDER BY 列名 ASC|DESC;注意事项ORDER BY 指定排序的列名可以是表中的列名, 也可以是SELECT语句后面起的别名ASC为升序, DESC为降序ORDER BY应在查询语句的结尾COUNT函数——语法SELECT COUNT(*)|COUNT(列名) from 表名 [WHERE 条件语句]注意事项COUNT(列名)的方式是统计指定列中有多少条记录, 不包括值为NULL的COUNT(*)则是统计表中有多少条数据COUNT(DISTINCT 列名) 统计不重复的记录数如果加上WHERE子句, 则是统计满足条件的记录