总结 前言 CentOS7 安装MySQL8详细步骤 CentOS7 环境下MySQL常用命令 在mysql中有一个默认的数据表information_schema,information_schema...这张数据表保存了MySQL服务器所有数据库的信息。...如数据库名,数据库的表,表栏的数据类型与访问权限等。...再简单点,这台MySQL服务器上,到底有哪些数据库、各个数据库有哪些表,每张表的字段类型是什么,各个数据库要什么权限才能访问,等等信息都保存在information_schema表里面,所以请勿删改此表...本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
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...='要查询的表名';
create table #Data(name varchar(100),row varchar(100),reserved varchar(100),data...
每个字段由若干按照某种界限划分的相同数据类型的数据项组成,这里指的数据表中的列,一列就是一个字段 1.1增 1.1.1列表的创建: create table 表名(字段名 列约束 [可选的参数] ,...方式一 show tables;查看该数据库内所有的列表 方式二 show create table 表名;查看具体表结构的详细信息 mysql> show create table hello; +...2.2字符串 char与varchar char是定长的,无论插入的字符是多少个,永远固定占规定的长度;varchar是变长的,根据掺入的字符串长度计算所占的字节数,它所占的内存中有一个字节用来存储字符串的大小...注意:如果在某些情况下不能确定数据的大小,建议使用varchar(255)。 char一般应用于固定长度的数据,如身份证、手机号、MD5加密之后的值。...数据库用户的创建与修改) 特殊表 (mysql.user) => 用户管理 ''' # 操作前提:登录root用户 1.重要字段 Host | User | Password 2.新建用户 create
第一章:表空间的拓展 ① 查看剩余表空间大小 查询剩余表空间(单位:M),小于1M将不显示。...② 查看表空间文件路径 查看表空间文件路径。 select name from v$datafile; 这个 23 结尾的表空间文件就是我自己建的。 ?...③ 通过新增表空间文件拓展表空间 拓展表空间方法,可以看到表空间文件 NCC_DATA01_1-23 共同组成了表空间 NCC_DATA01,所以我们直接在存储表空间路径的基础上再加上一个新的序列号表空间文件就好了...下面设置的是默认 500M 大小,以后剩余控件不足时,每次自动增加 200M。...ORALCE_HOME\ORADATA\NNC_DATA01_23.DBF' size 500M autoextend on next 200M maxsize unlimited; ④ 查看表空间已分配大小
查看一个数据中所有表的相关信息: (1)可以在命令下使用show table status \G命令查看: (2)如果想知道MySQL数据库中每个表占用的空间、表记录的行数的话,可以打开MySQL的 information_schema...在该库中有一个 TABLES 表,这个表主要字段分别是: TABLE_SCHEMA : 数据库名 TABLE_NAME:表名 ENGINE:所使用的存储引擎 TABLES_ROWS:记录数 DATA_LENGTH...:数据大小 INDEX_LENGTH:索引大小 其他字段请参考MySQL的手册,我们只需要了解这几个就足够了。...所以要知道一个表占用空间的大小,那就相当于是 数据大小 + 索引大小 即可。...'; 4.查看指定数据库各表容量大小 例:查看mysql库各表容量大小 select table_schema as '数据库', table_name as '表名', table_rows as
set 字符集 collate 校验规则 engine 存储引擎; 说明: field 表示列名 datatype 表示列的类型 character set 字符集,如果没有指定字符集,则以所在数据库的字符集为准...collate 校验规则,如果没有指定校验规则,则以所在数据库的校验规则为准 现在创建一张表user1: mysql> create table if not exists user1(...affected (0.00 sec) mysql> 创建表user2: mysql> create table if not exists user2( -> id int, -...(0.03 sec) 存储引擎不同,此时我们查看user1和user2:建表的时候出现不同的个数 不同的存储引擎对于磁盘文件的个数要求是不一样的 查看表desc 查看当前数据库的位置:select...修改表alter 在项目实际开发中,经常修改某个表的结构,比如字段名字,字段大小,字段类型,表的字符集类型,表的存储引擎等等。我们还有需求,添加字段,删除字段等等。这时我们就需要修改表。
MySQL基本查询 表的增删改查:CRUD Create(创建)包含insert Retrieve(读取)包含select Update(更新) Delete(删除) 一.增加数据Create 主要是...将上述SQL保存到文件中,然后在MySQL中使用source命令依次执行文件中的SQL。如下: 执行完文件中的SQL后查看数据库,就能看到多了一个名为scott的数据库。...如下: 进入该数据库,在该数据库中就可以看到雇员信息表中的三张表。...,都是对表进行各种的增删查改,尤其对于查找,表与表之间因外键的联系等。...但无疑,我们在上面的select 等语句,每一个过程都是对表进行操作,即筛选后的数据在逻辑上仍然是一张表,数据库本身也是一种表结构,所以,数据库下一切皆表。
– 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
MySQL表的增删改查(基础) 据库最主要的操作就是增(create)删(update)改(retrieve)查(delete)。(CURD) 注意:进行增删改查操作的时候,请务必选中数据库。...创建数据库,如果手动指定字符集了,以手动指定的为准,如果没有手动指定,此时就会读取MySQL的配置文件(my.ini),配置文件里面也会写一个字符集。...数据库服务区是把数据保存在硬盘上的。 mysql关系型数据库,每次进行一个sql操作,内部都会开启一个事务。每次开启事务也是有一定开销的。 查询(select) select是sql中最复杂的操作。...如果想要降序,那么手动指定desc(descend 降序)注意和上文desc(describe)表名区别。 MySQL中数据量是非常大的,因此有可能采用的是归并排序。...先把数据库中保存的数据,进行查询,查的时候,每次得到一行,就带入到条件中。 加入or就可以带上空值了。很多sql字句都是可以相互组合的。 这里是两个列进行比较。
MySQL 8.0以前,存放在以.frm为后缀的文件里 MySQL 8.0以后,表结构定义存放在系统数据表中 --查看test库表t的信息 desc test.t; show columns from...表数据单独存放成一个文件更容易管理,在我们执行drop table命令的时候,系统会直接删除这个文件,但如果是放在共享表空间中,即使表删掉空间也不会回收。 InnoDB的标记删除?...假设我们删除了R5这条记录,InnoDB引擎只会将R5这条记录标记为删除,并不是将页中该位置的数据置空,磁盘文件大小并不会缩小,这就是标记删除。...,得到一个逻辑数据上与表t相同的数据文件 用临时文件替换表t的数据文件 上述alter语句虽然在启动的时候会获取MDL写锁(阻塞增删改查),但MDL写锁在拷贝数据之前会退化成读锁(不会阻塞增删改查),整个...Inplace的 DDL过程如果是Inplace的,但不一定是Online的,比如MySQL8.0以前增加全文索引FULLTEXT和空间索引SPATIAL。
导读:深入学习MySQL的时候总是习惯性的和Oracle数据库进行比较。在学习MySQL InnoDB的存储结构的时候也免不了跟Oracle进行比较。...Oracle的数据存储有表空间、段、区、块、数据文件;MySQL InnoDB的存储管理也类似,但是MySQL增加了一个共享表空间和独立表空间的概念。...一、基本概念 共享表空间:Innodb的所有数据保存在一个单独的表空间里面,而这个表空间可以由很多个文件组成,一个表可以跨多个文件存在,所以其大小限制不再是文件大小的限制,而是其自身的限制。...默认的文件名为:ibdata1 初始化为10M 二、查看数据库的表空间 mysql> show variables like 'innodb_data%'; 我本地库比较小表空间主要由一个文件组成:ibdata1...以下是摘自mysql官方的一些介绍: 共享表空间的优点 表空间可以分成多个文件存放到各个磁盘,所以表也就可以分成多个文件存放在磁盘上,表的大小不受磁盘大小的限制(很多文档描述有点问题)。
临时表是执行sql语句过程中创建的中间过渡表,例如多表联合操作,就需要建立临时表 查看临时表的使用状态 mysql>show global status like 'created_tmp%'; created_tmp_tables...每次创建临时表时都会增加 created_tmp_disk_tables 如果是在磁盘上创建临时表,它会增加 created_tmp_files 表示MySQL服务创建的临时文件数 比较理想的配置是:...created_tmp_disk_tables / created_tmp_tables *100% <= 25% 再看一下临时表的配置: show variables like '%tmp_table_size...%'; tmp_table_size的默认值是32M,说明只有32M以下的临时表才能全部放在内存中,超过的就会用到硬盘临时表 可以适当增加此变量的值,例如 mysql> set session tmp_table_size...=40000000; 因为tmp_table_size变量是有作用域的,所以使用 'session'
Linux区分大小写规则 数据库名与表名严格区分大小写; 表的别名严格区分大小写; 列名与列的别名忽略大小写; 变量名严格区分大小写; windows下均不区分大小写。...配置支持大小写 Linux下配置my.cnf文件来决定是否支持大小写。...默认支持区分大小写,即等同于配置: lower_case_table_names=0 不区分大小写配置成如下即可: lower_case_table_names=1 一般情况下,此配置文件位于,/etc...通过vi命令进行修改,保存,重启mysql,即可生效。
在MySQL数据库中,有一个内置的database叫做information_schema, 该数据库中的tables表包含了数据库中所有表的基本信息,tables表结构如下: mysql> use information_schema...; Database changed mysql> describe tables; +-----------------+---------------------+------+-----+----...-------------+------+-----+---------+-------+ 21 rows in set (0.03 sec) 下面介绍几个主要关键字段: TABLE_SCHEMA: 表所属的数据库名...TABLE_NAME: 表名 TABLE_ROWS: 表行数 DATA_LENGTH: 数据总大小 INDEX_LENGTH: 索引总大小 DATA_FREE: 磁盘碎片大小 查看表大小语句示例如下:...mysql> select table_schema, table_name, concat(truncate(sum(DATA_LENGTH)/1024/1024,2),' MB') as data_size
1.创建表 首先创建一个 数据库 testForTable mysql> create database if not exists testForTable; 当前创建的 数据库 testForTable...创建一张 person 表,包含 姓名、性别、年龄 三个字段 注意: 创建表之前需要先使用数据库 mysql> create table if not exists person ( name varchar...当前表的字符集为 utf8,校验集为 utf8_general_ci,存储引擎为 InnoDB,这些都是数据库的 默认属性,只要我们在创建表时不指定属性,表就会继承数据库的默认属性 通过 InnoDB...三个文件 2.查看表 身处某个数据库中,可以通过 show tables 查看当前数据库中有哪些表 mysql> show tables; 当前数据库中就只有之前创建的两张表 2.1.查看表结构 知道有哪些表后...:列的注释、字符集、存储引擎,这也证明了当我们不指定这些属性时,自动使用数据库的默认属性 MySQL 会记录下用户的所有操作痕迹,这也是备份后,恢复数据库的关键,把所有指令再执行一遍,就能得到一模一样的数据库了
数据库约束 约束类型 NOT NULL 指示某列不能存储NULL值. UNIQUE 保证某列的每行必须有唯一的值。 数据库如何判定,当前这一条记录是重复的?先查找,再插入。...但是加上约束之后,数据库的执行过程可能就变了。因此执行时间或者效率会受到很大影响。 PRIMARY KEY 约束是可以组合在一起使用的。一列中可以同时加上多个约束。...注意: 实际开发中,大部分的表,一般都会带有一个主键,主键往往是一个整数表示的id 在mysql中,一个表里,只能有一个主键,不能有多个 虽然主键不能有多个,mysql允许把多个列放到一起共同作为一个主键...mysql的数据量比较小,所有的数据都在一个mysql服务器上,自增主键是可以很好地工作的,如果mysql的数据量很大,一台主机放不下就需要进行分库分表,使用多个主机来进行存储。...表的设计 表的设计/数据库的设计,要做的工作,就是明确一个程序里,需要使用几个数据库,几个表,表里有哪些列~ 设计表/数据库基本思路: 先明确实体 再明确实体之间的关系(关系是固定的套路:1.没关系
数据库约束 1.约束类型 NOT NULL - 指示某列不能存储 NULL 值。 UNIQUE - 保证某列的每行必须有唯一的值。 DEFAULT - 规定没有给列赋值时的默认值。...FOREIGN KEY - 保证一个表中的数据匹配另一个表中的值的参照完整性。 CHECK - 保证列中的值符合指定的条件。对于MySQL数据库,对CHECK子句进行分析,但是忽略CHECK子句。...,语法: foreign key (字段名) references 主表(列) 用例: -- 创建班级表,有使用MySQL关键字作为字段时,需要使用``来标识 DROP TABLE IF EXISTS...三大范式: 第一范式(1NF): 第一范式是指数据库表的每一列都是不可分割的基本数据项,同一列中不能有多个值,即实体中的某个属性不能有多个值,或不能有重复的属性。...如果联合查询,左侧的表完全显示我们就说是左外连接;右侧的表完全显示我们就说是右外连接。
用例:创建一张学生表 -- 创建一张学生表 DROP TABLE IF EXISTS student; CREATE TABLE student ( id INT, sn INT comment...VARCHAR(20) comment '姓名', qq_mail VARCHAR(20) comment 'QQ邮箱' ); 单行数据+全列插入 -- 插入两条记录,value_list 数量必须和定义表的列的数量及顺序一致...指定列查询 -- 指定列的顺序不需要按定义表的顺序来 SELECT id, name, math FROM exam_result; ?...别名: 为查询结果中的列指定别名,表示返回的结果集中,以别名作为该列的名称,语法: SELECT column [AS] alias_name [...]...[LIMIT ...] -- 删除表中某一数据 DELETE FROM 数据表名 WHERE 条件; -- 删除整表数据 DELETE FROM 数据库名; ?
领取专属 10元无门槛券
手把手带您无忧上云