`
ahcming
  • 浏览: 19322 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
最近访客 更多访客>>
社区版块
存档分类
最新评论

MySQL 使用

阅读更多

一,连接MySQL
格式:

mysql -h 远程主机地址 -u 用户名 -p
输入密码
mysql -u root -p
输入密码

 

mysql> 进入了
退出命令:>exit 或者ctrl+D

二,MySQL管理与授权
1.修改密码:
格式:

mysqladmin -u 用户名 -p 旧密码 password 新密码

 

2.增加新用户:

grant create,select,update....(授予相关的操作权限) on 数据库.* to 用户名@登录主机 identified by '密码'


操作实例:
给root用户添加密码:

# mysqladmin -u root password 52netseek

因为开始root没有密码,所以-p旧密码一项可以省略.

 

登陆测试:

# mysql -u root -p 
回车
输入密码

成功登陆.



将原有的mysql管理登陆密码52netseek改为52china.

# mysqladmin -u root -p 52netseek password '52china'


创建数据库添加用户并授予相应的权限:

mysql> create database phpbb;
Query OK, 1 row affected (0.02 sec)

mysql> use phpbb;
Database changed

mysql> grant create,select,update,insert,delete,alter on phpbb.* to phpbbroot@localhost identified by '52netseek';
Query OK, 0 rows affected (0.00 sec)

 

授予所有的权限:

mysql>grant all privileges on bbs.* to bbsroot@localhost identified by '52netseek'

 
回收权限:

rmysql>evoke create,select,update,insert,delete,alter on phpbb.* from phpbbroot@localhost identified by '52netseek';

 
完全将phpbbroot这个用户删除:

mysql>use mysql delete from user where user='phpbbroot' and  host='localhost';

mysql>flush privileges;                   // 刷新数据库

 
三,数据库简单操作
1.显示数据库列表:

mysql>show databases;

mysql
test

 

2.使其成为当前操作数据库

mysql>use mysql;                          // 打开数据库.
mysql>show tables;                      // 显示mysql数据库中的数据表.

 

3.显示数据表的表结构:

mysql>describe                             // 表名;
mysql>describe user;                   //显示user表的表结构:

 

4.创建数据库,建表

mysql>create database 数据库名;
mysql>use 数据库名;
mysql>create table 表名(字段设定列表)

 

5.删除数据库,册除表

mysql>drop database 数据库名;
mysql>drop table 表名;

 

6.显示表中的记录;

select * from 表名;
 

7.修改数据库结构:
增加字段:

alter table dbname add column <字段名><字段选项>


修改字段:

alter table dbname change <旧字段名> <新字段名><选项>

 

删除字段:

alter table dbname drop column <字段名>


实例操作:

mysql>create database office;

mysql>use office;

mysql> create table personal( member_no char(5) not null, name char(5), birthday date, exam_score tinyint, primary key(member_no) );
Query OK, 0 rows affected (0.01 sec)

mysql>desc personal;                        // 显示表结构
+------------+------------+------+-----+---------+-------+
|      Field     |       Type    |   Null  | Key |  Default  |  Extra |
+------------+------------+------+-----+---------+-------+
| member_no |    char(5)    |         |  PRI |            |           |
|      name    |    char(5)    |  YES  |       |   NULL   |          |
|   birthday   |     date       |  YES  |       |   NULL   |          |
| exam_score |   tinyint(4)   |  YES  |       |   NULL   |          |
+------------+------------+------+-----+---------+-------+
4 rows in set (0.00 sec)

mysql>insert into personal values ('001','netseek','1983-03-15','95');

mysql>insert into personal values ('002','heihei','1982-02-24','90');

mysql>insert into personal values ('003','gogo','1985-05-21','85');

mysql>insert into personal values ('004','haha','1984-02-25','84');

mysql>insert into personal values ('005','linlin','1982-04-28','85');

mysql>insert into personal values ('006','xinxin','1985-03-15','75');

mysql> select * from personal;
+-----------+---------+-------------+-------------+
| member_no|   name   |   birthday     | exam_score  |
+-----------+---------+-------------+-------------+
|      001     |  netseek | 1983-03-15  |       95        |
|      002     |   heihei   | 1982-02-24  |       90        |
|      003     |    gogo   | 1985-05-21  |       85        |
|      004     |    haha   | 1984-02-25  |       84        |
|      005     |    linlin    | 1982-04-28  |       85        |
|      006     |   xinxin   | 1985-03-15  |       75        |
+-----------+---------+-------------+-------------+
 

修改数据库表:
要求: 在birthday这后增加一个为height的字段,数据类型为tinyint.
将字段exam_score 改名为scores,数据类型不变

mysql>alter table personal add column height tinyint after birthday, change column exam_score scores tinyint;

mysql> select * from personal;
+-------------+---------+-------------+---------+---------+
|  member_no  |   name   |   birthday     |  height   |  scores  |
+-------------+---------+-------------+---------+---------+
|       001       |  netseek | 1983-03-15  |   NULL   |     95     |
|       002       |   heihei   | 1982-02-24  |   NULL   |     90     |
|       003       |    gogo   | 1985-05-21  |   NULL   |     85     |
|       004       |    haha   | 1984-02-25  |   NULL   |     84     |
|       005       |    linlin    | 1982-04-28  |   NULL   |     85     |
|       006       |    xinxin  | 1985-03-15   |  NULL    |    75      |
+-------------+---------+--------------+---------+---------+

 

给表中插入数据:

mysql>update personal set scores=95+5 where name='netseek';

mysql>select scores from personal where name='netseek';
+--------+
|  scores |
+--------+
|   100    |
+--------+

 
删除表名字为'gogo'所有的信息中的的:

msyql> delete from personal where name='gogo';


册除数据库中的表:

mysql>drop table if exists personal;


三,数据库的导入与导出
导出:
    使用select into outfile 'filename'语句
    使用mysqldump实用程序
    使用select into outfile 'filename'语句

1.只能处理单个表,输出文件只有数据,没有表结构
我们要将office,其中有一个表为personal,现在要把personal卸成文本文件out.txt:

msyql>use office;
mysql>select * from personal into outfile 'out.txt';                 // 可以看在/var/lib/mysql/office/目录下有out.txt

mysql>select * from personal into outfile './out.txt';               // 可以看在out.txt 在/var/lib/mysql/目录下用out.txt


2.使用mysqldump实用程序(可以轻松处理多个表)

# cd /var/lib/mysql
导出建立相关表的建表命令和插入指令
# mysqldump bbs >bbs.sql 将数据库bbs导入到bbs.sql中


如果要将bbs.sql导入数据库可以使用:

mysql> create database bbstest;                    // 先建立一个名为office 的数据库.
# mysql bbstest <bbs.sql                                (这个常用在将本地的数据库文件传到服务器上,再导入到数据库中)

 
只想导出建表指令:

# mysqldump -d bbs >bbscreate.sql


只想导出插入数据的sql指令:

# mysqldump -t bbs >bbsinsert.sql


同时导出数据库中建表指令和表中的数据:

# mysqldump -T./ bbs cdb_admingroups   (其中./表示当前目录,cdb_admingroups为bbs数据库其中的一个表)
#ls
cdb_admingroups.sql                    导出了建表指令
cdb_admingroups.txt                    导出了表中的数据

 

导入:
从文件中加载数据库:

mysql>load data infile "/tmp/name.txt" into table names;

mysql>select * from names;


四,数据库备份

1.手动拷贝备份:
MySQL数据库的文件保存在目录/var/lib/mysql中,数据库为每个库建立一个目录,所有的数据库文件都在这些目录中.

[root@linuxhero mysql]#ls
[root@linuxhero mysql]#servcie mysqld stop             先停止数据库
bbs mysql mysql.sock phpbb test office                      显示其中的数据库.

 

如果我们要将现在的数据库目录备份为mysql.bak .

[root@linuxhero lib]# cp -rf mysql mysql.bak

 

如果数据库遭到了破坏,现在要将数据库恢复:

[root@linuxhero lib]# cp -rf mysql.bak/* mysql
 

恢复数据库以后,var/lib/mysql中的文件已改变了,要更改文件的所属权限必须改变MySQL数据库的用户读写权限。
所以我们得启动和运行mysql,并登陆数据库:

[root@linuxhero lib]# /etc/init.d/mysqld start

[root@linuxhero lib]# mysql -u root -p
Enter password:输入密码
成功登陆.

mysql> show databses;

 

2.利用mysqldump来备份数据库

[root@linuxhero mysql]# mysqldump --opt bbs -u root -p > bbs.sql
Enter password:

 

注:--opt添加备份的其它选项,bb为其中一个数据库名,
上面的意思是:使用重定向输出将备份写入到文件bb.sql中.

[root@linuxhero mysql] #less bbs.sql


如果要恢复bb这个数据库,则进行如下操作:

[root@linuxhero mysql] #mysql bbs -u root -p < bbs.sql

 

如果要备份所有数据库:

[root@linuxhero mysql] #mysqldump --opt --all-databases -u root -p >mysql.bak
Enetr password:输入密码即可

 

恢复所有数据库,不用输入数据库的名字:

[root@linuxhero mysql] #mysql -u root -p < mysql.bak
Enetr password: 输入密码即可

 

分享到:
评论

相关推荐

    Navicat for mysql使用说明文档

    Navicat for MySQL 使用说明文档 Navicat 是一套安裝在 PC 上的 MySQL 資料庫系統遠端管理及開發工具。它不僅適合資深的專業研發者,也適合新手輕鬆的學習。Navicat 友善的圖形化使用介面,使用者可以快速且簡易的...

    MySql使用手册(详细)

    MySql使用手册MySql使用手册MySql使用手册MySql使用手册MySql使用手册MySql使用手册MySql使用手册MySql使用手册MySql使用手册MySql使用手册MySql使用手册MySql使用手册MySql使用手册MySql使用手册MySql使用手册MySql...

    mysql使用疑难问题汇总

    教程名称:mysql使用疑难问题汇总课程目录:【】10个节省时间的MySQL命令【】DB2环境变量管理方法集【】Linux下MySQL整个数据库的备份与还原【】MaxDB数据库和MySQL数据库的主要差别【】MySQL内存表的特性与使用介绍...

    c# 和MySql 使用的 SqlHelper

    c# 和MySql 使用的 SqlHelper

    linux下MySQL使用方法.docx

    ### Linux下MySQL使用方法 #### 一、引言 随着技术的发展,Linux系统因其稳定性、安全性及开源特性,在服务器领域占据着重要的位置。对于数据库应用而言,MySQL在Linux平台上的表现同样优秀。对于初次接触Linux并...

    Mysql使用存储过程快速添加百万数据.docx

    Mysql 使用存储过程快速添加百万数据 Mysql 是一个流行的关系型数据库管理系统,它提供了存储过程的功能,可以用来快速添加大量数据。在本文中,我们将介绍如何使用 Mysql 存储过程快速添加百万数据,并讨论相关的...

    mysql 使用手册 超全中文版

    mysql 使用手册 超全中文版

    C#中iBatis连接mySQL使用的DLL

    C#中iBatis连接mySQL使用的DLL

    基于Flink CDC使用datastream方式全量增量同步mysql to mysql

    基于Flink CDC使用datastream方式全量增量同步mysql to mysql 使用的是java语言,只需配置完源数据库和目标数据库信息,运行MysqlCDC中的main函数,即可实现多库多表同步。

    mysql安装和使用

    MySQL是一种广泛使用的开源关系型数据库管理系统,以其高效、稳定和易于管理的特点,成为了许多企业和开发者首选的数据库解决方案。本文将详细介绍MySQL的安装过程以及基本使用方法。 首先,我们需要下载MySQL的...

    MySQL使用指南.pdf

    根据所提供的文件内容,我们可以挖掘以下关于MySQL8使用指南的知识点: 1. MySQL数据库管理系统概述: - MySQL是一个关系型数据库管理系统,它使用结构化查询语言(SQL)进行数据库管理。 - MySQL的主要特点包括...

    mysql 使用及中文正常显示

    mysql 使用及中文正常显示,解决中文支持问题

    MYSQL使用大全

    MySQL 使用大全 MySQL 是一种关系型数据库管理系统,主要用于存储和管理数据。以下是 MySQL 的安装、配置、服务启动和关闭、数据库常用操作、数据类型等相关知识点。 MySQL 的安装和配置 MySQL 的安装可以通过...

    mysql中文使用手册

    ### MySQL中文使用手册知识点概览 #### 1. MySQL 的基本信息 **1.1 什么是 MySQL?** - MySQL 是一款关系型数据库管理系统(RDBMS),由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。 - 主要用于存储、检索数据...

    MySQL使用临时表加速查询的方法

    本文实例讲述了MySQL使用临时表加速查询的方法。分享给大家供大家参考。具体分析如下: 使用MySQL临时表,有时是可以加速查询的,下面就为您详细介绍使用MySQL临时表加速查询的方法。 把表的一个子集进行排序并创建...

    Navicat-for-MySQL使用教程

    Navicat_for_MySQL使用教程

    04. [MAC] 安装WordPress与建立MySQL使用者

    [WordPress][教學][架站]_04.__[MAC]_安裝WordPress與建立MySQL使用者

    mysql使用教程指南.doc

    mysql使用教程指南.doc

Global site tag (gtag.js) - Google Analytics