mysql基础命令操作

1、连接mysql

mysql -u username(root) -p

输入密码,连接mysql

2、创建数据库

create database yiqing;

查看是否创建成功

show databases;

3、在数据库中建表

use yiqing;(切换到要建表的数据库)

create tablename (id varchar(20) NOT NULL,name varchar(10) NOT NULL);

增加表字段

alter table tablename add newcol varchar

如 alter table ship add tel varcha(11);

4、增加用户

grant 权限(select insert update ) on 数据库.* to 用户名@登录主机 identified by “密码”;


4.1、增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。

grant select,insert,update,delete on *.* to test1@”%” Identified by “abc”;

4.2、增加一个用户test2密码为abc,让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作

grant select,insert,update,delete on mydb.* to test2@localhost identified by “abc”;


5、创建数据库  create database <数据库名>


5.1  建立一个名为yihua的数据库

create database yihua;

5.2  创建数据库并分配用户

create database yihua;

GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP,ALTER ON yihua.* TO yihua@localhost IDENTIFIED BY '密码';

    SET PASSWORD FOR 'yihua'@'localhost' = OLD_PASSWORD('密码');

依次执行3个命令完成数据库创建。注意:中文 “密码”和“数据库”是户自己需要设置的。


6、 删除数据库  drop database <数据库名>

6.1 删除一个已经确定存在的数据库

mysql> drop database drop_database;

6.2 删除一个不确定存在的数据库

  mysql> drop database drop_database;

  ERROR 1008 (HY000): Can't drop database 'drop_database'; database doesn't exist

     //发生错误,不能删除'drop_database'数据库,该数据库不存在。

  mysql> drop database if exists drop_database;

  Query OK, 0 rows affected, 1 warning (0.00 sec)//产生一个警告说明此数据库不存在

  mysql> create database drop_database;

  Query OK, 1 row affected (0.00 sec)

  mysql> drop database if exists drop_database;//if exists 判断数据库是否存在,不存在也不产生错误

  Query OK, 0 rows affected (0.00 sec)

7、创建表

create table <表名> ( <字段名1> <类型1> [,..<字段名n> <类型n>]);


mysql> create table MyClass(

> id int(4) not null primary key auto_increment,

> name char(20) not null,

> sex int(4) not null default '0',

> degree double(16,2));


8、删除表 drop table <表名>

删除表名为 MyClass 的表

  mysql> drop table MyClass;


DROP TABLE用于取消一个或多个表。您必须有每个表的DROP权限。所有的表数据和表定义会被取消,所以使用本语句要小心!


注意:对于一个带分区的表,DROP TABLE会永久性地取消表定义,取消各分区,并取消储存在这些分区中的所有数据。DROP TABLE还会取消与被取消的表有关联的分区定义(.par)文件。


对与不存在的表,使用IF EXISTS用于防止错误发生。当使用IF EXISTS时,对于每个不存在的表,会生成一个NOTE。


9、插入表数据  insert into <表名> [( <字段名1>[,..<字段名n > ])] values ( 值1 )[, ( 值n )]


例如:往表 MyClass中插入二条记录, 这二条记录表示:编号为1的名为Tom的成绩为96.45, 编号为2 的名为Joan 的成绩为82.99, 编号为3 的名为Wang 的成绩为96.5。

mysql> insert into MyClass values(1,'Tom',96.45),(2,'Joan',82.99), (2,'Wang', 96.59);


注意:insert into每次只能向表中插入一条记录。


10、备份数据库

命令在DOS的[url=file://\\mysql\\bin]\\mysql\\bin[/url]目录下执行


1.导出整个数据库

导出文件默认是存在mysql\bin目录下

   mysqldump -u 用户名 -p 数据库名 > 导出的文件名

   mysqldump -u user_name -p123456 database_name > outfile_name.sql


2.导出一个表

   mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名

   mysqldump -u user_name -p database_name table_name > outfile_name.sql


3.导出一个数据库结构

   mysqldump -u user_name -p -d –add-drop-table database_name > outfile_name.sql

   -d 没有数据 –add-drop-table 在每个create语句之前增加一个drop table


4.带语言参数导出

   mysqldump -uroot -p –default-character-set=latin1 –set-charset=gbk –skip-opt database_name > outfile_name.sql


例如,将aaa库备份到文件back_aaa中:

  [root@test1 root]# cd /home/data/mysql

  [root@test1 mysql]# mysqldump -u root -p --opt aaa > back_aaa


11、实例

11.1

drop database if exists school; //如果存在SCHOOL则删除

create database school; //建立库SCHOOL

use school; //打开库SCHOOL

create table teacher //建立表TEACHER

(

   id int(3) auto_increment not null primary key,

   name char(10) not null,

   address varchar(50) default ''深圳'',

   year date

); //建表结束


//以下为插入字段

insert into teacher values('''',''glchengang'',''深圳一中'',''1976-10-10'');

insert into teacher values('''',''jack'',''深圳一中'',''1975-12-23'');


注:在建表中

1、将ID设为长度为3的数字字段:int(3);并让它每个记录自动加一:auto_increment;并不能为空:not null;而且让他成为主字段primary key。


2、将NAME设为长度为10的字符字段


3、将ADDRESS设为长度50的字符字段,而且缺省值为深圳。


4、将YEAR设为日期字段。


11.2

drop database if exists school; //如果存在SCHOOL则删除

create database school; //建立库SCHOOL

use school; //打开库SCHOOL

create table teacher //建立表TEACHER

(

   id int(3) auto_increment not null primary key,

   name char(10) not null,

   address varchar(50) default ‘深圳’,

   year date

); //建表结束


//以下为插入字段

insert into teacher values(”,’allen’,'大连一中’,'1976-10-10′);

insert into teacher values(”,’jack’,'大连二中’,'1975-12-23′);


如果你在mysql提示符键入上面的命令也可以,但不方便调试。

1、你可以将以上命令原样写入一个文本文件中,假设为school.sql,然后复制到c:\\下,并在DOS状态进入目录[url=file://\\mysql\\bin]\\mysql\\bin[/url],然后键入以下命令:

   mysql -uroot -p密码 < c:\\school.sql

如果成功,空出一行无任何显示;如有错误,会有提示。(以上命令已经调试,你只要将//的注释去掉即可使用)。


2、或者进入命令行后使用 mysql> source c:\\school.sql; 也可以将school.sql文件导入数据库中。