首页 > 编程知识 正文

更改mysql数据库的存储位置,怎么更改mysql数据的位置

时间:2023-12-28 11:56:39 阅读:327497 作者:PTQY

本文目录一览:

linux 怎么更改mysql数据库储存

mnt目录下建立mysql_data目录

#cd /mnt

#mkdir mysql_data

把MySQL服务服务停掉。

#service mysql stop

把/var/lib/mysql整个目录移到/mnt/mysql_data。

#mv /usr/local/mysql/data /mnt/mysql_data

重新设置数据权限。

#cd /mnt/mysql_data

修改my.cnf配置文件

#vi /etc/my.cnf

指明mysql.sock文件的产生位置。用符号#注释掉原来socket,

修改MySQL启动脚本。

#vi /etc/init.d/mysql

找到datadir。

datadir = /mnt/mysql_data

7

重启mysql服务

#service mysql start

好了,至此数据库目录位置已迁移完毕。

如何更改MySQL数据库的默认目录位置

1.停止数据库服务:

使用/etc/init.d/mysql

stop

或者

stop

mysql

2.

在目标位置(/data)创建数据库文件的目录(如/mysqldb),并复制(如果不再使用默认的位置,则可以直接mv原先数据库文件到新目录下)原先的数据库文件目录到该目录下:

cd

/data

mkdir

mysqldb

cp

-r

/var/lib/mysql

/data/mysqldb/

经过一段时间的等待后,在/data/mysqldb/下面就有了原先默认的mysql数据库文件目录的拷贝“/mysql”

3.修改my.cnf文件

#

vim

/etc/mysql/my.cnf

将datadir

=

/var/lib/mysql

改为

datadir

=

/data/mysqldb/mysql

另外由于当前my.cnf

中的socket

=

/var/run/mysqld/mysqld.sock(而并非像网上所说的sock

=

/var/lib/mysql/mysql.sock),即socket的位置并不在数据库文件所在的位置,因此可以不做类似网上其他网页所说的,要使用以下的命令做一个mysql.sock

链接:

ln

-s

/data/mysqldb/mysql/mysql.sock

/var/lib/mysql/mysql.sock

(需要从/home/data/mysql下复制一份过来)

4.

修改数据库的权限:

#

chown

-r

mysql:mysql

/data/mysqldb/mysql/ 

改变数据库文件目录的归属为mysql

#

chmod

700

/data/mysqldb/mysql/whois/ 

改变数据库目录whois的属性为700

#

chmod

660

/data/mysqldb/mysql/whois/* 

改变数据库中数据表的属性为660

5.

修改文件usr.sbin.mysqld

#

vim

/etc/apparmor.d/usr.sbin.mysqld

/var/lib/mysql

r,

/var/lib/mysql/**

rwk,

改成

/data/mysqldb/mysql/

r,

/data/mysqldb/mysql/**

rwk,

注意:没有该步骤的话,将导致数据库服务无法重启,好像在重启,但是一直卡住无反应。

6.启动mysql服务器

/etc/init.d/apparmor

restart

/etc/init.d/mysql

restart

(或者使用

restart

mysql)

如何更改mysql数据文件位置

一.首先把mysql的服务先停掉。

二.更改MySQL配置文件My.ini中的数据库存储主路径

打开MySQL默认的安装文件夹C:Program FilesMySQLMySQL Server 5.1中的my.ini文件,点击记事本顶部的“编辑”,“查找”,在查找内容中输入datadir后并点击“查找下一个”转到“Path to the database root数据库存储主路径”参数设置,找到datadir="C:/Documents and Settings/All Users/Application Data/MySQL/MySQL Server 5.1/Data/"即是默认的数据库存储主路径设置,现将它改到C:mysqldata(你希望的)文件夹,正确的设置是datadir="C:/mysql/data/"。

更改完成后点击菜单栏的“文件”,再点击“保存”。

三.将老的数据库存储主路径中的数据库文件和文件夹复制到新的存储主路径

将C:/Documents and Settings/All Users/Application Data/MySQL/MySQL Server 5.1/Data/文件夹中的所有文件和文件夹拷贝到你新建的文件夹目录下。

四.重启MySQL服务

五.验证更改数据库存储主路径的操作是否成功

Linux Mysql如何移动MySQL数据库目录位置?

假如要把目录移到/home/data下需要进行下面几步:

1、home目录下建立data目录

cd /home

mkdir data

2、把MySQL服务进程停掉:

mysqladmin -u root -p shutdown

3、把/var/lib/mysql整个目录移到/home/data

mv /var/lib/mysql /home/data/

这样就把MySQL的数据文件移动到了/home/data/mysql下

4、找到my.cnf配置文件

如果/etc/目录下没有my.cnf配置文件,请到/usr/share/mysql/下找到*.cnf文件,拷贝其中一个到/etc/并改名为my.cnf)中。命令如下:

[root@test1 mysql]# cp /usr/share/mysql/my-medium.cnf /etc/my.cnf

5、编辑MySQL的配置文件/etc/my.cnf

为保证MySQL能够正常工作,需要指明mysql.sock文件的产生位置。修改socket=/var/lib/mysql/mysql.sock一行中等号右边的值为:/home/mysql/mysql.sock 。操作如下:

vi  my.cnf  (用vi工具编辑my.cnf文件,找到下列数据修改之)

# The MySQL server

[mysqld]

port = 3306

#socket  = /var/lib/mysql/mysql.sock(原内容,为了更稳妥用“#”注释此行)

socket  = /home/data/mysql/mysql.sock (加上此行)

6、修改MySQL启动脚本/etc/init.d/mysql

最后,需要修改MySQL启动脚本/etc/init.d/mysql,把其中datadir=/var/lib/mysql一行中,等号右边的路径改成你现在的实际存放路径:home/data/mysql。

[root@test1 etc]# vi /etc/init.d/mysql

#datadir=/var/lib/mysql(注释此行)

datadir=/home/data/mysql (加上此行)

7、重新启动MySQL服务

/etc/init.d/mysql start

或用reboot命令重启Linux

如果工作正常移动就成功了,否则对照前面的7步再检查一下。还要注意目录的属主和权限。

mysql数据库存储路径怎么更改?

MySql安装过程中,没有修改掉数据存储位置的话,可能会是数据存储到自己并不希望的位置,故需要修改

先利用命令行登录数据库

mysql -u root -p

查看数据库数据存储位置

show variables like '%datadir%'

去该目录下找到文件夹中的所有文件(该目录一般是隐藏的),将其中所有文件拷贝到你希望数据文件存储的位置,

我是想拷贝到D:/MySQl/data目录下的

打开安装目录下的my.ini文件,将datadir="C:/ProgramData/MySQL/MySQL Server 5.5/data/",这行修改为datadir="DMySQLdata"(这里用又斜线,否则有可能报错)。

退出所有对mysql.exe的调用,任务管理器看一下服务MySQL有没有停止,如果没有,在cmd中命令net stop mysql停止服务。然后在net start mysql重新启动服务

查询数据库位置,查看是否成功

如何查看和更改mysql数据库文件存放位置

这个取决于你用什么backend

engine了,myisam,

innodb和ndb有不同的设置方法,innodb的我不太清楚(有可能是设置conf/config.ini里[mysql]下的datadir参数),ndbcluster是在conf/config.ini里面,设置[ndbd]的datadir参数

参考:

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。