在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,就是:原来的还是按照原来的方式存储。新的表按照新的规则来存储。
使用命令行创建MySql数据库,首先要登录MySql数据库系统
创建步骤如下:
Windows操作系统下,开始——运行,打开"运行"对话框,输入cmd,点击“确定”即可进入DOS窗口,输入登录MySQL数据库命令
mysql -h 127.0.0.1 -u root -p
参数含义:
mysql是登录数据库的命令,-h 后面跟服务器的IP,由于本示例MySql服务器安装在本地,因此IP地址为127.0.0.1;-u 后面跟用户名,本示例采用 root用户登录;-p 后面跟登录密码。
输入上述命令后回车,再输入登录密码,一般默认密码是root
回车
成功登录MySQL数据库后就可以在DOS下使用SQL语句"create database"创建数据库了
mysqlcreate database 要创建的新数据库名;
相关操作附图:
图中的mydb1就是新创建的数据库
网络供应商的话都有个后台,你登录到供应商提供的后台上,里面就有数据库操作
在虚拟机上安装mysql的步骤为:
1、下载MySQL-5.5.24-1.rhel5.i386.tar
在/usr/local 下建立必要文件夹
# cd /usr/local
# mkdir mysql
# cd /usr/local/mysql
# mkdir src
# mkdir data
用xftp将MySQL-5.5.16-1.rhel5.i386.tar 上传到虚拟机src目录下
2、解压:# tar -xvf MySQL-5.5.16-1.rhel5.i386.tar
在src目录下安装服务端:
rpm -ivh MySQL-server-5.5.16-1.rhel5.i386.rpm
3、启动mysql服务:service mysql start
查看mysql端口3306是否启动:netstat –nat
看到3306端口,如图表明服务端安装成功。
在src目录下安装MySQL客户端
# rpm -ivh MySQL-client-5.5.16-1.rhel5.i386.rpm
查看mysql状态:/etc/init.d/mysql status
停止mysql:/etc/init.d/mysql stop
启动mysql:/etc/init.d/mysql start
4、修改密码:/usr/bin/mysqladmin –u root password ‘000000’
数据库目录 cd: /var/lib/mysql/
配置文件 :/usr/share/mysql(mysql.server命令及配置文件)
相关命令:/usr/bin/mysql*(mysqladmin mysqldump等命令)
5、更改MySQL目录,由于MySQL数据库目录占用磁盘比较大,而MySQL默认的数据文件存储目录为/"var/lib/mysql",所以要把目录移到"/"根目录下的"mysql_data"目录中。
"/"根目录下建立"mysql_data"目录
停掉mysql:service mysql stop 或者 mysqladmin –u root –p shutdown
把"/var/lib/mysql"整个目录移到"/mysql_data"
修改配置文件 cp /usr/share/mysql/my-medium点吸烟 f /etc/my点吸烟 f
对"my-medium点吸烟 f"进行配置
vim /etc /my点吸烟 f