现在的位置: 首页 > 综合 > 正文

mysql

2013年02月21日 ⁄ 综合 ⁄ 共 23952字 ⁄ 字号 评论关闭

一,连接MySQL

二,MySQL管理与授权

三,数据库简单操作

四, 数据库备份

五,后记

一,连接MySQL

格式:mysql -h 远程主机地址 -u 用户名 -p 回车

输入密码进入:

 

mysql -u root -p 回车

Enter password: ,输入密码就可以进入

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> grantcreate,select,update,insert,delete,alter

-> on phpbb.*

-> to phpbbroot@localhost identified by'52netseek';

Query OK, 0 rows affected (0.00 sec)

 

授予所有的权限:

>grant all privileges

>on bbs.*

>to bbsroot@localhost identified by'52netseek'

 

回收权限:

revokecreate,select,update,insert,delete,alter

on phpbb.*

from phpbbroot@localhost identified by'52netseek';

 

完全将phpbbroot这个用户删除:

>use mysql

>delete from user

where user='phpbbroot' andhost='localhost';

>flush privileges; 刷新数据库

 

三,数据库简单操作

1.显示数据库列表:

>show databases;

mysql

test

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

>use mysql; 打开数据库.

>show tables; 显示mysql数据库中的数据表.

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

>describe 表名;

>describe user; 显示user表的表结构:

4.创建数据库,建表

>create database 数据库名;

>use 数据库名;

>create table 表名(字段设定列表)

5.删除数据库,册除表

>drop database 数据库名;

>drop table 表名;

6.显示表中的记录;

select * from 表名;

7.修改数据库结构:

增加字段:

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

修改字段:

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

删除字段:

alter table dbname drop column <字段名>

 

实例操作:

>create database office;

>use office;

mysql> create table personal(

-> member_no char(5) not null,

-> name char(,

-> birthday date,

-> exam_score tinyint,

-> primary key(member_no)

-> );

Query OK, 0 rows affected (0.01 sec)

>desc personal; 显示表结构:

+------------+------------+------+-----+---------+-------+

| Field | Type | Null | Key | Default |Extra |

+------------+------------+------+-----+---------+-------+

| member_no | char(5) | | PRI | | |

| name | char( | YES | | NULL | |

| birthday | date | YES | | NULL | |

| exam_score | tinyint(4) | YES | | NULL ||

+------------+------------+------+-----+---------+-------+

4 rows in set (0.00 sec)

 

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

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

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

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

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

 

您正在看的MySQL教程是: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,数据类型不变

>alter table personal

->add column height tinyint afterbirthday,

->change column exam_score scorestinyint;

 

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 |

+-----------+---------+------------+--------+--------+

 

给表中插入数据:

>update personal set scores=95+5 wherename='netseek';

>select scores from personal wherename='netseek';

+--------+

| scores |

+--------+

| 100 |

+--------+

 

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

> delete from personal wherename='gogo';

 

册除数据库中的表:

mysql>drop table if exists personal;

 

三,数据库的导入与导出

导出:

使用select intooutfile 'filename'语句

使用mysqldump实用程序

使用select intooutfile 'filename'语句

 

1.只能处理单个表,输出文件只有数据,没有表结构

我们要将office,其中有一个表为personal,现在要把personal卸成文本文件out.txt:

>use office;

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

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 mysqlmysql.bak

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

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

恢复数据库以后,var/lib/mysql中的文件已改变了,要更改文件的所属权限必须改变MySQL数据库的用户读写权限。

所以我们得启动和运行mysql,并登陆数据库:

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

[root@linuxhero lib]# mysql

 

您正在看的MySQL教程是: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: 输入密码即可

 

五,后记:

MySQL数据库个人学习笔记,这是我个人学习过程中的一个简单的总结,这些都是常用的,希望对于希望学习mysql的朋友有所帮助,如果有什么不对或者不妥的地方请多多指教,欢迎大家与我交流学习Linux相关的知识

 

 

 

 

 

 

 

MySQL学习(二)

 

第一招、mysql服务的启动和停止
net stop mysql
net start mysql

第二招、登陆mysql
语法如下: mysql -u用户名-p用户密码
键入命令mysql -uroot -p, 回车后提示你输入密码,输入12345,然后回车即可进入到mysql中了,mysql的提示符是:
mysql>
注意,如果是连接到另外的机器上,则需要加入一个参数-h机器IP

第三招、增加新用户
格式:grant 权限 on 数据库.* to 用户名@登录主机 identified by "密码"
如,增加一个用户user1密码为password1,让其可以在本机上登录, 并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入mysql,然后键入以下命令:
grant select,insert,update,delete on *.* to user1@localhostIdentified by "password1";
如果希望该用户能够在任何机器上登陆mysql,则将localhost改为"%"。
如果你不想user1有密码,可以再打一个命令将密码去掉。
grant select,insert,update,delete on mydb.* to user1@localhostidentified by "";

第四招: 操作数据库
登录到mysql中,然后在mysql的提示符下运行下列命令,每个命令以分号结束。
1、 显示数据库列表。
show databases;
缺省有两个数据库:mysql和test。 mysql库存放着mysql的系统和用户权限信息,我们改密码和新增用户,实际上就是对这个库进行操作。
2、 显示库中的数据表:
use mysql;
show tables;
3、 显示数据表的结构:
describe 表名;
4、 建库与删库:
create database 库名;
drop database 库名;
5、 建表:
use 库名;
create table 表名(字段列表);
drop table 表名;
6、 清空表中记录:
delete from 表名;
7、 显示表中的记录:
select * from 表名;

第五招、导出和导入数据
1. 导出数据:
mysqldump --opt test > mysql.test
即将数据库test数据库导出到mysql.test文件,后者是一个文本文件
如:mysqldump -u root -p123456 --databasesdbname > mysql.dbname
就是把数据库dbname导出到文件mysql.dbname中。
2. 导入数据:
mysqlimport -u root -p123456 < mysql.dbname。
不用解释了吧。
3. 将文本数据导入数据库:
文本数据的字段数据之间用tab键隔开。
use test;
load data local infile "文件名" into table 表名;
1:使用SHOW语句找出在服务器上当前存在什么数据库:
mysql> SHOW DATABASES;
2:2、创建一个数据库MYSQLDATA
mysql> CREATE DATABASE MYSQLDATA;
3:选择你所创建的数据库
mysql> USE MYSQLDATA; (按回车键出现Database changed 时说明操作成功!)
4:查看现在的数据库中存在什么表
mysql> SHOW TABLES;
5:创建一个数据库表
mysql> CREATE TABLE MYTABLE (name VARCHAR(20), sex CHAR(1));
6:显示表的结构:
mysql> DESCRIBE MYTABLE;
7:往表中加入记录
mysql> insert into MYTABLE values ("hyq","M");
8:用文本方式将数据装入数据库表中(例如D:/mysql.txt)
mysql> LOAD DATA LOCAL INFILE "D:/mysql.txt" INTO TABLE MYTABLE;
9:导入.sql文件命令(例如D:/mysql.sql)
mysql>use database;
mysql>source d:/mysql.sql;
10:删除表
mysql>drop TABLE MYTABLE;
11:清空表
mysql>delete from MYTABLE;
12:更新表中数据
mysql>update MYTABLE set sex="f" where name='hyq'; posted on2006-01-10 16:21 happytian 阅读(6) 评论(0) 编辑 收藏 收藏至365Key13:备份数据库mysqldump -u root 库名>xxx.data14:例2:连接到远程主机上的MYSQL

  假设远程主机的IP为:110.110.110.110,用户名为root,密码为abcd123。则键入以下命令:    

  mysql-h110.110.110.110 -uroot -pabcd123   

  (注:u与root可以不用加空格,其它也一样)   

  3、退出MYSQL命令: exit 第一招、mysql服务的启动和停止
net stop mysql
net start mysql

第二招、登陆mysql
语法如下: mysql -u用户名-p用户密码
键入命令mysql -uroot -p, 回车后提示你输入密码,输入12345,然后回车即可进入到mysql中了,mysql的提示符是:
mysql>
注意,如果是连接到另外的机器上,则需要加入一个参数-h机器IP

第三招、增加新用户
格式:grant 权限 on 数据库.* to 用户名@登录主机 identified by "密码"
如,增加一个用户user1密码为password1,让其可以在本机上登录, 并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入mysql,然后键入以下命令:
grant select,insert,update,delete on *.* to user1@localhostIdentified by "password1";
如果希望该用户能够在任何机器上登陆mysql,则将localhost改为"%"。
如果你不想user1有密码,可以再打一个命令将密码去掉。
grant select,insert,update,delete on mydb.* to user1@localhostidentified by "";

第四招: 操作数据库
登录到mysql中,然后在mysql的提示符下运行下列命令,每个命令以分号结束。
1、 显示数据库列表。
show databases;
缺省有两个数据库:mysql和test。 mysql库存放着mysql的系统和用户权限信息,我们改密码和新增用户,实际上就是对这个库进行操作。
2、 显示库中的数据表:
use mysql;
show tables;
3、 显示数据表的结构:
describe 表名;
4、 建库与删库:
create database 库名;
drop database 库名;
5、 建表:
use 库名;
create table 表名(字段列表);
drop table 表名;
6、 清空表中记录:
delete from 表名;
7、 显示表中的记录:
select * from 表名;

第五招、导出和导入数据

 

 

 

 

 

 

MySQL使用初级教程

 

 

如果MYSQL运行在服务器上,而你在客户端需要连接的化,需要按如下方式进行连接:

shell>mysql -h host -u user -p

Enter password:************

 

host和user分别代表MySQL服务器运行的主机名和MySQL帐户名.添写时写上对应的机器的名称和MySQL用户名. *********代表你的密码.

如果有效,你会看到如下提示:

 

Welcome to the MySQL monitor.   Commands end with ; or \g.

Your MySQL connection id is 7 to serverversion: 5.0.18-nt

 

Type ’help;’ or ’\h’ for help. Type ’\c’ toclear the buffer.

 

mysql>

 

mysql>提示符告诉你该输入命令了.

有些时候MySQL会允许你匿名登陆到服务器上,此时直接输入mysql即可.

shell> mysql

成功连接后,可在mysql>提示下输入quit随时退出:

mysql> quit

 

Bye

 

下面显示一个简单的查询实例,这是一个简单命令,要求得到服务器的版本号和当前日期:

 

mysql> select version(), current_date;

+-----------+--------------+

| version() | current_date |

+-----------+--------------+

| 5.0.18-nt| 2006-07-29 |

+-----------+--------------+

1 row in set (0.00 sec)

 

mysql>

 

在这里我们要明白:

一个命令通常由SQL语句组成,随后跟着一个分号.

 

MySQL的显示结果用表格(行和列)方式输出.第一行为列的标签,随后行为查询的结果.通常列标签是你查询的数据库表的列名,但若检索的是一表达式而非列值(如上一个例子),通常用表达式本

身来标记列.

 

随后它会显示返回了多少行以及查询时间,它提供了服务器性能的一个大致估计.它表示的是时钟时间并非CPU或机器时间.

 

能够以大小写输入关键字,即在MySQL中大小写是等价的,但在一个查询语句中,要求大小写统一.

 

以下是另一个查询:

 

mysql> SELECT SIN(PI()/4), (4+1)*5;

+------------------+---------+

| SIN(PI()/4)    | (4+1)*5 |

+------------------+---------+

| 0.70710678118655 |    25 |

+------------------+---------+

1 row in set (0.02 sec)

 

mysql>

 

可以在一行上输入多条语句,如:

 

mysql> SELECT VERSION(); SELECT NOW();

+-----------------+

| VERSION()    |

+-----------------+

| 5.1.2-alpha-log|

+-----------------+

1 row in set (0.00 sec)

 

+---------------------+

| NOW()             |

+---------------------+

| 2005-10-11 15:15:00 |

+---------------------+

1 row in set (0.00 sec)

 

mysql>

 

较长的命令可以分多行输入.MySQL是通过分号来判断语句是否结束,而不是换行.

下面是一个简单的多行语句的例子:

 

mysql> select

-> user(),

-> current_date;

+---------------+--------------+

| USER()        | CURRENT_DATE |

+---------------+--------------+

| jon@localhost | 2005-10-11|

+---------------+--------------+

 

mysql>

 

在这个例子中,输入多行查询的第一行后,你可以看提示符变为 ->,这就是说MySQL没有找到语句结束标识正在等待剩余的输入部分. 如果不想执行正在输入过程的一个命令,输入\c 取消它:

mysql> select

-> user()

-> \c

 

mysql>

 

下面显示的是各个提示符以及它们所表示的MySQL的状态:

 

提示符   含义

 

mysql>  准备好接受新命令。

 

->  等待多行命令的下一行。

 

’>   等待下一行,等待以单引号(“’”)开始的字符串的结束。

 

">  等待下一行,等待以双引号(“"”)开始的字符串的结束。

 

`>  等待下一行,等待以反斜点(‘`’)开始的识别符的结束。

 

/*>  等待下一行,等待以/*开始的注释的结束。

\

 

MYSQL命令大全

常见的MySQL命令大全
一、连接MySQL
        格式: mysql -h主机地址 -u用户名 -p用户密码
        1、例1:连接到本机上的MYSQL。
        首先在打开DOS窗口,然后进入目录 mysqlbin,再键入命令mysql -uroot -p,回车后提示你输密码,如果刚安装好MYSQL,超级用户root是没有密码的,故直接回车即可进入到MYSQL中了,MYSQL的提示符是:mysql>。
        2、例2:连接到远程主机上的MYSQL。假设远程主机的IP为:110.110.110.110,用户名为root,密码为abcd123。则键入以下命令:
        mysql -h110.110.110.110 -uroot -pabcd123
        (注:u与root可以不用加空格,其它也一样)
        3、退出MYSQL命令: exit (回车)。
        二、修改密码
        格式:mysqladmin -u用户名 -p旧密码 password 新密码
        1、例1:给root加个密码ab12。首先在DOS下进入目录mysqlbin,然后键入以下命令:
        mysqladmin -uroot -password ab12
        注:因为开始时root没有密码,所以-p旧密码一项就可以省略了。
        2、例2:再将root的密码改为djg345。
        mysqladmin -uroot -pab12 password djg345
        三、增加新用户。(注意:和上面不同,下面的因为是MySQL环境中的命令,所以后面都带一个分号作为命令结束符)
        格式:grant selecton 数据库.* to 用户名@登录主机 identified by \"密码\"
        例1、增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入MySQL,然后键入以下命令:
        grant select,insert,update,
        delete on *.* to [email=test2@localhost]test2@localhost[/email] identified by\"abc\";
        如果你不想test2有密码,可以再打一个命令将密码消掉。
        grant select,insert,update,delete on mydb
        .* to [email=test2@localhost]test2@localhost[/email] identified by\"\";
        在上面讲了登录、增加用户、密码更改等问题。下面我们来看看MySQL中有关数据库方面的操作。注意:你必须首先登录到MySQL中,以下操作都是在MySQL的提示符下进行的,而且每个命令以分号结束。
1、MySQL常用命令
create database name; 创建数据库
use databasename; 选择数据库
drop database name 直接删除数据库,不提醒
show tables; 显示表
describe tablename; 表的详细描述
select 中加上distinct去除重复字段
mysqladmin drop database name 删除数据库前,有提示。
显示当前mysql版本和当前日期
select version(),current_date;
2、修改mysql中root的密码:
shell>mysql -u root -p
mysql> update user set password=password(”xueok654123″) where user=’root’;
mysql> flush privileges //刷新数据库
mysql>use dbname; 打开数据库:
mysql>show databases; 显示所有数据库
mysql>show tables; 显示数据库mysql中所有的表:先use mysql;然后
mysql>describe user; 显示表mysql数据库中user表的列信息);
3、grant
创建一个可以从任何地方连接服务器的一个完全的超级用户,但是必须使用一个口令something做这个
mysql> grant all privileges on *.* to [email=user@localhost]user@localhost[/email] identified by ’something’with
增加新用户
格式:grant select on 数据库.* to 用户名@登录主机 identified by “密码”
GRANT ALL PRIVILEGES ON *.* TO [email=monty@localhost]monty@localhost[/email]IDENTIFIED BY ’something’ WITH GRANT OPTION;
GRANT ALL PRIVILEGES ON *.* TO [email=monty@%E2%80%9D%]monty@”%[/email]”IDENTIFIED BY ’something’ WITH GRANT OPTION;
删除授权:
mysql> revoke all privileges on *.* from [email=root@%E2%80%9D%]root@”%[/email]”;
mysql> delete from user where user=”root” and host=”%”;
mysql> flush privileges;
创建一个用户custom在特定客户端it363.com登录,可访问特定数据库fangchandb
mysql >grant select, insert, update, delete, create,drop on fangchandb.* tocustom@ it363.com identified by ‘ passwd’
重命名表:
mysql > alter table t1 rename t2;
4、mysqldump
备份数据库
shell> mysqldump -h host -u root -p dbname >dbname_backup.sql
恢复数据库
shell> mysqladmin -h myhost -u root -p create dbname
shell> mysqldump -h host -u root -p dbname < dbname_backup.sql
如果只想卸出建表指令,则命令如下:
shell> mysqladmin -u root -p -d databasename > a.sql
如果只想卸出插入数据的sql命令,而不需要建表命令,则命令如下:
shell> mysqladmin -u root -p -t databasename > a.sql
那么如果我只想要数据,而不想要什么sql命令时,应该如何操作呢?
   mysqldump -T./ phptest driver
其中,只有指定了-T参数才可以卸出纯文本文件,表示卸出数据的目录,./表示当前目录,即与mysqldump同一目录。如果不指定driver 表,则将卸出整个数据库的数据。每个表会生成两个文件,一个为.sql文件,包含建表执行。另一个为.txt文件,只包含数据,且没有sql指令。
5、可将查询存储在一个文件中并告诉mysql从文件中读取查询而不是等待键盘输入。可利用外壳程序键入重定向实用程序来完成这项工作。例如,如果在文件my_file.sql 中存放有查
询,可如下执行这些查询:
例如,如果您想将建表语句提前写在sql.txt中:
mysql > mysql -h myhost -u root -p database < sql.txt
1、安装环境:
      Windows XP
      Mysql 4.0.17 从     下次就需要用mysql -uroot -proot才可以登陆
    在远程或本机可以使用 mysql -h 172.5.1.183 -uroot 登陆,这个根据第二行的策略确定
    权限修改生效:
       1)net stop mysql
         net start mysql
       2)c:\mysql\bin\mysqladmin flush-privileges
       3)登陆mysql后,用flush privileges语句
6、创建数据库staffer
    create database staffer;
7、下面的语句在mysql环境在执行
    显示用户拥有权限的数据库       show databases;
    切换到staffer数据库       use staffer;
    显示当前数据库中有权限的表 show tables;
    显示表staffer的结构   desc staffer;
8、创建测试环境
    1)创建数据库staffer
      mysql> create database staffer
    2)创建表staffer,department,position,depart_pos
      create table s_position
      (
          id int not null auto_increment,
          name varchar(20) not null default '经理', #设定默认值
          description varchar(100),
          primary key PK_positon (id)  #设定主键
      );   
      create table department
      (
          id int not null auto_increment,
          name varchar(20) not null default '系统部', #设定默认值
          description varchar(100),
          primary key PK_department (id)  #设定主键
      );
      create table depart_pos
      (
          department_id int not null,
          position_id int not null,
          primary key PK_depart_pos(department_id,position_id)   #设定复和主键
      );
      create table staffer
      (
          id int not null auto_increment primarykey,   #设定主键
          name varchar(20) not null default '无名氏',   #设定默认值
          department_id int not null,
          position_id int not null,
          unique(department_id,position_id)   #设定唯一值
      );
    3)删除
      mysql>
         drop table depart_pos;
         drop table department;
         drop table s_position;
         drop table staffer;
         drop database staffer;
9、修改结构
    mysql>
    #表position增加列test
    alter table position add(test char(10));
    #表position修改列test
    alter table position modify test char(20) not null;
    #表position修改列test默认值
    alter table position alter test set default 'system';
    #表position去掉test默认值
    alter table position alter test drop default;
    #表position去掉列test
    alter table position drop column test;
    #表depart_pos删除主键
    alter table depart_pos drop primary key;
    #表depart_pos增加主键
    alter table depart_pos add primary key PK_depart_pos(department_id,position_id);
10、操作数据
    #插入表department
    insert into department(name,description) values('系统部','系统部');
    insert into department(name,description) values('公关部','公关部');
    insert into department(name,description) values('客服部','客服部');
    insert into department(name,description) values('财务部','财务部');
    insert into department(name,description) values('测试部','测试部');
    #插入表s_position
    insert into s_position(name,description) values('总监','总监');
    insert into s_position(name,description) values('经理','经理');
    insert into s_position(name,description) values('普通员工','普通员工');
    #插入表depart_pos
    insert into depart_pos(department_id,position_id)
    select a.id department_id,b.id postion_id
    from department a,s_position b;
    #插入表staffer
    insert into staffer(name,department_id,position_id) values('陈达治',1,1);
    insert into staffer(name,department_id,position_id) values('李文宾',1,2);
    insert into staffer(name,department_id,position_id) values('马佳',1,3);
    insert into staffer(name,department_id,position_id) values('亢志强',5,1);
    insert into staffer(name,department_id,position_id) values('杨玉茹',4,1);
11、查询及删除操作
    #显示系统部的人员和职位
    select a.name,b.name department_name,c.name position_name
    from staffer a,department b,s_position c
    where a.department_id=b.id and a.position_id=c.id and b.name='系统部';
    #显示系统部的人数
    select count(*) from staffer a,department b
    where a.department_id=b.id and b.name='系统部'
    #显示各部门的人数
    select count(*) cou,b.name
    from staffer a,department b
    where a.department_id=b.id
    group by b.name;
    #删除客服部
    delete from department where name='客服部';
    #将财务部修改为财务一部
    update department set name='财务一部' wherename='财务部';
12、备份和恢复
     备份数据库staffer
      c:\mysql\bin\mysqldump -uroot -prootstaffer>e:\staffer.sql
      得到的staffer.sql是一个sql脚本,不包括建库的语句,所以你需要手工
      创建数据库才可以导入
     恢复数据库staffer,需要创建一个空库staffer
      c:\mysql\bin\mysql -uroot -prootstaffer<staffer.sql
      如果不希望后来手工创建staffer,可以
      c:\mysql\bin\mysqldump -uroot -proot --databasesstaffer>e:\staffer.sql
      mysql -uroot -proot >e:\staffer.sql
      但这样的话系统种就不能存在staffer库,且无法导入其他名字的数据库,
      当然你可以手工修改staffer.sql文件
13、从文本向数据库导入数据
     1)使用工具c:\mysql\bin\mysqlimport
     这个工具的作用是将文件导入到和去掉文件扩展名名字相同的表里,如
     staffer.txt,staffer都是导入到staffer表中
     常用选项及功能如下
-d or --delete 新数据导入数据表中之前删除数据数据表中的所有信息
-f or --force 不管是否遇到错误,mysqlimport将强制继续插入数据
-i or --ignore mysqlimport跳过或者忽略那些有相同唯一
关键字的行, 导入文件中的数据将被忽略。
-l or -lock-tables 数据被插入之前锁住表,这样就防止了,
你在更新数据库时,用户的查询和更新受到影响。
-r or -replace 这个选项与-i选项的作用相反;此选项将替代
表中有相同唯一关键字的记录。
--fields-enclosed- by= char
指定文本文件中数据的记录时以什么括起的, 很多情况下
数据以双引号括起。 默认的情况下数据是没有被字符括起的。
--fields-terminated- by=char
指定各个数据的值之间的分隔符,在句号分隔的文件中,
分隔符是句号。您可以用此选项指定数据之间的分隔符。
默认的分隔符是跳格符(Tab)
--lines-terminated- by=str
此选项指定文本文件中行与行之间数据的分隔字符串
或者字符。 默认的情况下mysqlimport以newline为行分隔符。
您可以选择用一个字符串来替代一个单个的字符:
一个新行或者一个回车。
mysqlimport命令常用的选项还有-v 显示版本(version),
             -p 提示输入密码(password)等。
    这个工具有个问题,无法忽略某些列,这样对我们的数据导入有很大的麻烦,虽然
    可以手工设置这个字段,但会出现莫名其妙的结果,我们做一个简单的示例
    我们定义如下的depart_no.txt,保存在e盘,间隔为制表符\t
10 10
11 11
12 24
执行如下命令
     c:\mysql\bin\mysqlimport -uroot -proot staffere:\depart_pos.txt
     在这里没有使用列的包围符号,分割采用默认的\t,因为采用别的符号会有问题,
     不知道是不是windows的原因
     2)Load Data INFILE file_name intotable_name(column1_name,column2_name)
       这个命令在mysql>提示符下使用,优点是可以指定列导入,示例如下
       c:\mysql\bin\mysql -uroot -proot staffer
       mysql>load data infile"e:/depart_no.txt" into depart_no(department_id,position_id);
     这两个工具在Windows下使用都有问题,不知道是Windows的原因还是中文的问题,
     而且不指定的列它产生了空值,这显然不是我们想要的,所以谨慎使用这些工具
进入MySQL:mysql -uuser -ppassword --port=3307
1:使用SHOW语句找出在服务器上当前存在什么数据库:
mysql> SHOW DATABASES;
2:2、创建一个数据库MYSQLDATA
mysql> Create DATABASE MYSQLDATA;
3:选择你所创建的数据库
mysql> USE MYSQLDATA; (按回车键出现Database changed 时说明操作成功!)
4:查看现在的数据库中存在什么表
mysql> SHOW TABLES;
5:创建一个数据库表
mysql> Create TABLE MYTABLE (name VARCHAR(20), sex CHAR(1));
6:显示表的结构:
mysql> DESCRIBE MYTABLE;
7:往表中加入记录
mysql> insert into MYTABLE values ("hyq","M");
8:用文本方式将数据装入数据库表中(例如D:/mysql.txt)
mysql> LOAD DATA LOCAL INFILE "D:/mysql.txt" INTO TABLE MYTABLE;
9:导入.sql文件命令(例如D:/mysql.sql)
mysql>use database;
mysql>source d:/mysql.sql;
10:删除表
mysql>drop TABLE MYTABLE;
11:清空表
mysql>delete from MYTABLE;
12:更新表中数据
mysql>update MYTABLE set sex="f" where name='hyq';
UPDATE [LOW_PRIORITY] [IGNORE] tbl_name
    SET col_name1=expr1 [, col_name2=expr2 ...]
    [WHERE where_definition]
    [ORDER BY ...]
    [LIMIT rows]
or
UPDATE [LOW_PRIORITY] [IGNORE] tbl_name [, tbl_name ...]
    SET col_name1=expr1 [, col_name2=expr2 ...]
    [WHERE where_definition]
UPDATE 以新的值更新现存表中行的列。SET 子句指出要修改哪个列和他们应该给定的值。WHERE
      子句如果被给出,指定哪个记录行应该被更新。否则,所有的记录行被更新。如果 ORDER BY 子句被指定,记录行将被以指定的次序更新。
      如果你指定关键词 LOW_PRIORITY,UPDATE 的执行将被延迟,直到没有其它的客户端正在读取表。
      如果你指定关键词 IGNORE,该更新语句将不会异常中止,即使在更新过程中出现重复键错误。导致冲突的记录行将不会被更新。
      如果在一个表达式中从 tbl_name 中访问一个列,UPDATE 使用列的当前值。举例来说,下面的语句设置 age 列值为它的当前值加 1 :
mysql> UPDATE persondata SET age=age+1;
UPDATE 赋值是从左到右计算的。举例来说,下列语句将 age 列设置为它的两倍,然后再加 1 :
mysql> UPDATE persondata SET age=age*2, age=age+1;
如果你设置列为其当前的值,MySQL 注意到这点,并不更新它。
      UPDATE 返回实际被改变的记录行数目。在 MySQL3.22 或更新的版本中,C API 函数mysql_info()
      返回被匹配并更新的记录行数目,以及在 UPDATE 期间发生的警告的数目。
      在 MySQL 3.23 中,你可以使用 LIMIT # 来确保只有给定的记录行数目被更改。
      如果一个 ORDER BY 子句被使用(从 MySQL 4.0.0 开始支持),记录行将以指定的次序被更新。这实际上只有连同 LIMIT
      一起才有用。
      从 MySQL 4.0.4 开始,你也可以执行一个包含多个表的 UPDATE 的操作:
UPDATE items,month SET items.price=month.price
WHERE items.id=month.id;
注意:多表 UPDATE 不可以使用 ORDER BY 或 LIMIT。
关键字:   mysql   
启动:net start mySql;
  进入:mysql -u root -p/mysql -h localhost -u root -pdatabaseName;
  列出数据库:show databases;
  选择数据库:use databaseName;
  列出表格:show tables;
  显示表格列的属性:show columns from tableName;
  建立数据库:source fileName.txt;
  匹配字符:可以用通配符_代表任何一个字符,%代表任何字符串;
  增加一个字段:alter table tabelName add column fieldNamedateType;
  增加多个字段:alter table tabelName add column fieldName1dateType,add columns fieldName2 dateType;
  多行命令输入:注意不能将单词断开;当插入或更改数据时,不能将字段的字符串展开到多行里,否则硬回车将被储存到数据中;
  增加一个管理员帐户:grant all on *.* to [email=user@localhost]user@localhost[/email] identified by"password";
  每条语句输入完毕后要在末尾填加分号';',或者填加'\g'也可以;
  查询时间:select now();
  查询当前用户:select user();
  查询数据库版本:select version();
  查询当前使用的数据库:select database();
  1、删除student_course数据库中的students数据表:
  rm -f student_course/students.*
  2、备份数据库:(将数据库test备份)
  mysqldump -u root -p test>c:\test.txt
  备份表格:(备份test数据库下的mytable表格)
  mysqldump -u root -p test mytable>c:\test.txt
  将备份数据导入到数据库:(导回test数据库)
  mysql -u root -p test
  3、创建临时表:(建立临时表zengchao)
  create temporary table zengchao(name varchar(10));
  4、创建表是先判断表是否存在
  create table if not exists students(……);
  5、从已经有的表中复制表的结构
  create table table2 select * from table1 where1<>1;
  6、复制表
  create table table2 select * from table1;
  7、对表重新命名
  alter table table1 rename as table2;
  8、修改列的类型
  alter table table1 modify id int unsigned;//修改列id的类型为int unsigned
  alter table table1 change id sid int unsigned;//修改列id的名字为sid,而且把属性修改为intunsigned
  9、创建索引
  alter table table1 add index ind_id (id);
  create index ind_id on table1 (id);
  create unique index ind_id on table1 (id);//建立唯一性索引
  10、删除索引
  drop index idx_id on table1;
  alter table table1 drop index ind_id;
  11、联合字符或者多个列(将列id与":"和列name和"="连接)
  select concat(id,':',name,'=') from students;
  12、limit(选出10到20条)<第一个记录集的编号是0>
  select * from students order by id limit 9,10;
  13、MySQL不支持的功能
  事务,视图,外键和引用完整性,存储过程和触发器
  14、MySQL会使用索引的操作符号
  <,<=,>=,>,=,between,in,不带%或者_开头的like
  15、使用索引的缺点
  1)减慢增删改数据的速度;
  2)占用磁盘空间;
  3)增加查询优化器的负担;
  当查询优化器生成执行计划时,会考虑索引,太多的索引会给查询优化器增加工作量,导致无法选择最优的查询方案;
  16、分析索引效率
  方法:在一般的SQL语句前加上explain;
  分析结果的含义:
  1)table:表名;
  2)type:连接的类型,(ALL/Range/Ref)。其中ref是最理想的;
  3)possible_keys:查询可以利用的索引名;
  4)key:实际使用的索引;
  5)key_len:索引中被使用部分的长度(字节);
  6)ref:显示列名字或者"const"(不明白什么意思);
  7)rows:显示MySQL认为在找到正确结果之前必须扫描的行数;
  8)extra:MySQL的建议;
  17、使用较短的定长列
  1)尽可能使用较短的数据类型;
  2)尽可能使用定长数据类型;
  a)用char代替varchar,固定长度的数据处理比变长的快些;
  b)对于频繁修改的表,磁盘容易形成碎片,从而影响数据库的整体性能;
  c)万一出现数据表崩溃,使用固定长度数据行的表更容易重新构造。使用固定长度的数据行,每个记录的开始位置都是固定记录长度的倍数,可以很容易被检测到,但是使用可变长度的数据行就不一定了;
  d)对于MyISAM类型的数据表,虽然转换成固定长度的数据列可以提高性能,但是占据的空间也大;
  18、使用not null和enum
  尽量将列定义为not null,这样可使数据的出来更快,所需的空间更少,而且在查询时,MySQL不需要检查是否存在特例,即null值,从而优化查询;
  如果一列只含有有限数目的特定值,如性别,是否有效或者入学年份等,在这种情况下应该考虑将其转换为enum列的值,MySQL处理的更快,因为所有的enum值在系统内都是以标识数值来表示的;
  19、使用optimize table
  对于经常修改的表,容易产生碎片,使在查询数据库时必须读取更多的磁盘块,降低查询性能。具有可变长的表都存在磁盘碎片问题,这个问题对 blob数据类型更为突出,因为其尺寸变化非常大。可以通过使用optimizetable来整理碎片,保证数据库性能不下降,优化那些受碎片影响的数据表。 optimize table可以用于MyISAM和BDB类型的数据表。实际上任何碎片整理方法都是用mysqldump来转存数据表,然后使用转存后的文件并重新建数据 表;
  20、使用procedure analyse()
  可以使用procedure analyse()显示最佳类型的建议,使用很简单,在select语句后面加上procedure analyse()就可以了;例如:
  select * from students procedure analyse();
  select * from students procedure analyse(16,256);
  第二条语句要求procedure analyse()不要建议含有多于16个值,或者含有多于256字节的enum类型,如果没有限制,输出可能会很长;
  21、使用查询缓存
  1)查询缓存的工作方式:
  第一次执行某条select语句时,服务器记住该查询的文本内容和查询结果,存储在缓存中,下次碰到这个语句时,直接从缓存中返回结果;当更新数据表后,该数据表的任何缓存查询都变成无效的,并且会被丢弃。
  2)配置缓存参数:
  变量:query_cache _type,查询缓存的操作模式。有3中模式,0:不缓存;1:缓存查询,除非与 select sql_no_cache开头;2:根据需要只缓存那些以select sql_cache开头的查询; query_cache_size:设置查询缓存的最大结果集的大小,比这个值大的不会被缓存。
  22、调整硬件
  1)在机器上装更多的内存;
  2)增加更快的硬盘以减少I/O等待时间;
  寻道时间是决定性能的主要因素,逐字地移动磁头是最慢的,一旦磁头定位,从磁道读则很快;
  3)在不同的物理硬盘设备上重新分配磁盘活动;
  如果可能,应将最繁忙的数据库存放在不同的物理设备上,这跟使用同一物理设备的不同分区是不同的,因为它们将争用相同的物理资源(磁头)。

 

抱歉!评论已关闭.