mysql如何建表空间
在mysql中,也出现了类似oracle中的表空间概念。
不过二者好像不同?具体不太清楚oracle是怎么回事。
mysql表空间是什么概念呢?
开启了Innodb的innodb_file_per_table这个参数之后【innodb_file_per_table=1】,也就是启用InnoDB的独立表空间模式,便于管理。此时,在新建的innodb表的数据库目录下会多出来一个.ibd这个文件。这个就是此时的数据文件了。mysql会把这个innodb表的数据存放在这个文件中。并且每个innodb表此时都会对应这么一个ibd文件。
看官方文档:
Ifinnodb_file_per_tableisdisabled(thedefault),InnoDBcreatestablesinthesystemtablespace.Ifinnodb_file_per_tableisenabled,InnoDBcreateseachnewtableusingitsown.ibdfileforstoringdataandindexes,ratherthaninthesystemtablespace.
那么这样做有什么好处呢?
可以实现单表在不同的数据库之间移动。具体怎么移动呢?假设有两个数据库,一个test,一个tt。
InnoDB默认会将所有的数据库InnoDB引擎的表数据存储在一个共享空间中:ibdata1,这样就感觉不爽,增删数据库的时候,ibdata1文件不会自动收缩,单个数据库的备份也将成为问题。通常只能将数据使用mysqldump导出,然后再导入解决这个问题。共享表空间在Insert操作上少有优势。其它都没独立表空间表现好。当启用独立表空间时,请合理调整一下innodb_open_files的值。
-------------------------------------------------------------------------------
需要说明的是:
1、设置了独立表空间之后,如果改成了共享表空间,那么,此时如果执行表的插入操作,数据会存放在哪里呢?
对于之前已经存在了的表,还是存放在独立表空间。对于新建的表,就会存放在共享表空间了。
2、如果一开始用了独立表空间,后来改了innodb_file_per_table变量的值,改成独立表空间了,那么数据如何存储?
对于已经存在了的innodb引擎的表来说,数据还是存放在共享表空间的,而此时如果创建了新的表,那么就会在数据库的目录中多出一个.ibd的文件用于存储这个新表的数据。
总结上面的1、2,就是:原来的还是按照原来的方式存储。新的表按照新的规则来存储。
oracle 在创建表空间时 让其 建立的表含有默认的初始大小
创建表空间常用语法如下:CREATE TABLESPACE TESTDATAFILE 'E:\ORACLE\ORADATA\ORCL\TEST01.DBF' SIZE 50M REUSEEXTENT MANAGEMENT DICTIONARYDEFAULT STORAGE (INITIAL 50KNEXT 50KMINEXTENTS 2MAXEXTENTS 50PCTINCREASE 0);存储选项通过DEFAULT STORAGE子句指定。
MY SQL 的数据库里默认的表大小是多少?这个大小能更改的吧?怎样更改的了?
mysql如何建表空间
在mysql中,也出现了类似oracle中的表空间概念。
不过二者好像不同?具体不太清楚oracle是怎么回事。
mysql表空间是什么概念呢?
开启了Innodb的innodb_file_per_table这个参数之后【innodb_file_per_table = 1】,也就是启用InnoDB的独立表空间模式,便于管理。此时,在新建的innodb表的数据库目录下会多出来一个.ibd这个文件。这个就是此时的数据文件了。mysql会把这个innodb表的数据存放在这个文件中。并且每个innodb表此时都会对应这么一个ibd文件。
看官方文档:
If innodb_file_per_table is disabled (the default), InnoDB creates tables in the system tablespace. Ifinnodb_file_per_table is enabled, InnoDB creates each new table using its own .ibd file for storing data and indexes, rather than in the system tablespace.
那么这样做有什么好处呢?
可以实现单表在不同的数据库之间移动。具体怎么移动呢?假设有两个数据库,一个test,一个tt。
InnoDB 默认会将所有的数据库InnoDB引擎的表数据存储在一个共享空间中:ibdata1,这样就感觉不爽,增删数据库的时候,ibdata1文件不会自动收缩,单个数据库的备份也将成为问题。通常只能将数据使用mysqldump 导出,然后再导入解决这个问题。共享表空间在Insert操作上少有优势。其它都没独立表空间表现好。当启用独立表空间时,请合理调整一 下innodb_open_files 的值。
-------------------------------------------------------------------------------
需要说明的是:
1、设置了独立表空间之后,如果改成了共享表空间,那么,此时如果执行表的插入操作,数据会存放在哪里呢?
对于之前已经存在了的表,还是存放在独立表空间。对于新建的表,就会存放在共享表空间了。
2、如果一开始用了独立表空间,后来改了innodb_file_per_table变量的值,改成独立表空间了,那么数据如何存储?
对于已经存在了的innodb引擎的表来说,数据还是存放在共享表空间的,而此时如果创建了新的表,那么就会在数据库的目录中多出一个.ibd的文件用于存储这个新表的数据。
总结上面的1、2,就是:原来的还是按照原来的方式存储。新的表按照新的规则来存储。auti_increment 前加上int:
mysql> create table userstate(userstateid int auto_increment not null primary ke
y, usestatename varchar(50) not null);
query ok, 0 rows affected (0.08 sec)
mysql> desc userstate;
+--------------+-------------+------+-----+---------+----------------+
| field| type| null | key | default | extra|
+--------------+-------------+------+-----+---------+----------------+
| userstateid | int(11)| no| pri | null| auto_increment |
| usestatename | varchar(50) | no|| null||
+--------------+-------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)