• mysql在linux下命令备份数据库


    mysql在linux下命令备份数据库
    2010-07-09 11:25

    如果机子上装有mysql,可以直接输入mysql进入。 

     

       1:打开的数据库的命令 

      mysql> use mysql 
      Database changed 
      2:查看数据库的命令 

      mysql> show databases; 
        3:查看数据库中表的命令 
        mysql> show tables; 
       4:查看表的详细结构 
        mysql> desc tablename; 
       5:新建数据库 
        mysql> create database school; 
      Query OK, 1 row affected (0.00 sec) 
       6:新建表 

      mysql> create table user01( 

      -> id varchar(20) NOT NULL, 

      -> userName varchar(10) NOT NULL, 

      -> age int(11) default'0', 

      -> sex char(2) NOT NULL default'm', 

      -> PRIMARY KEY (id) 

      -> )TYPE=InnoDB; 

      Query OK, 0 rows affected, 1 warning (0.02 sec)mysql>desc student; 
        7:插入 

      mysql> insert into student(id,stuName) values('1','tomcat'); 

      Query OK, 1 row affected (0.00 sec) 

      8:删除 

      mysql> delete from student where id='1'; 

      Query OK, 1 row affected (0.01 sec) 

      9:删除表中所有数据 

      mysql> truncate table student; 

      Query OK, 1 row affected (0.01 sec) 

        10:创建新用户并给予权限 

      mysql>grant all privileges on *.* to dbsync@"127.0.0.1" identified by "1234"; 

      11:更改Mysql用户密码 

      c:\Mysql5.0\bin>mysqladmin -u root -p password 1234 

      Enter password: **** 
    备份数据库及表 

      我们用mysqldump命令来备份数据库 

      c:\mysql\bin\>mysqldump –u root –p 3306 mysql>d:\backup.sql 

      执行此语句将把mydb 备份到D盘的backup.sql文件中 

      备份多个数据库表 

      c:\mysql\bin\>mysqldump –u root –p 3306 school user01 user >d:\backup.sql 

      此句的意思是把school库中的user01表和user表的内容和表的定义备份到D盘backup.sql文件中。 

      备份所有的数据库 

      c:\myql\bin>mysqldump –u root –p 3306 –all –database>d:backup.sql 

      还原Mysql数据库 

      c:\mysql\bin\mysql –u root –p 3306 school 

      还原其中的一个表 

      mysql> source d:\books.sql;

    备份数据库则应该在普通的命令输入地方。不要进入mysql的命令输入框。

    输入mysqldump -uroot -p mdwk >/usr/mysqlback/mdwk2010-07-09.sql;则可

    1 mysqlldump命令 

        mysqldump 是采用SQL级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,这也是最常用的备份方法。 

        使用 mysqldump进行备份非常简单,如果要备份数据库” db_backup ”,使用命令:

    #mysqldump –u -p phpbb_db_backup > /usr/backups/mysql/db_backup2008-1-6.sql

        还可以使用gzip命令对备份文件进行压缩:

    #mysqldump db_backup | gzip > /usr/backups/mysql/ db_backup2008-1-6.sql.gz

        只备份一些频繁更新的数据库表:

    ## mysqldump sample_db articles comments links > /usr/backups/mysql/sample_db.art_comm_lin.2008-1-6.sql

        上面的命令会备份articles, comments, 和links 三个表。 

        恢复数据使用命令:

    #mysql –u -p db_backup </usr/backups/mysql/ db_backup2008-1-6.sql

        注意使用这个命令时必须保证数据库正在运行。 

        2 使用 SOURCE 语法 

        其实这不是标准的 SQL 语法,而是 mysql 客户端提供的功能,例如:

    # SOURCE /tmp/db_name.sql;

        这里需要指定文件的绝对路径,并且必须是 mysqld 运行用户(例如 nobody)有权限读取的文件。 

        3 mysqlhotcopy备份 

        mysqlhotcopy 只能用于备份 MyISAM,并且只能运行在 linux 和Unix 和 NetWare 系统上。mysqlhotcopy 支持一次性拷贝多个数据库,同时还支持正则表达。以下是几个例子:

    #mysqlhotcopy -h=localhost -u=goodcjh -p=goodcjh db_name /tmp

        (把数据库目录 db_name 拷贝到 /tmp 下) 
        注意,想要使用 mysqlhotcopy,必须要有 SELECT、RELOAD(要执行 FLUSH TABLES) 权限,并且还必须要能够有读取 datadir/db_name 目录的权限。 

        还原数据库方法:

        mysqlhotcopy 备份出来的是整个数据库目录,使用时可以直接拷贝到 mysqld 指定的 目录 (在这里是 /usr/local/mysql/data/)目录下即可,同时要注意权限的问题,另外首先应当删除数据库旧副本如下例:

    # /bin/rm -rf /mysql-backup/*old

        关闭mysql 服务器、复制文件、查询启动mysql服务器的三个步骤:

  • 相关阅读:
    Course Schedule II
    Vim笔记
    python programming
    暴风电视刷机教程
    python asyncio
    sqlalchemy lock and atomic
    rust学习(二)
    rust-vmm 学习(二)
    e3s10 网络管理
    打造VIM成为IDE - nerdtree
  • 原文地址:https://www.cnblogs.com/moonvan/p/2523788.html
Copyright © 2020-2023  润新知