1、用户操作:
1.1 用户密码设置
mysql -u root //第一次启动时
mysql> SET PASSWORD FOR = PASSWORD('12345678');
mysqladmin -u root password "newpass"//注意是双引号
Enter password:***** //注意输入的是旧的密码
1.2 增加用户
可以增加不使用密码访问的远程用户:
mysql> Grant all privileges on *.* to 'root'@'%' with grant option;
增加使用密码访问的远程用户:
mysql> Grant all privileges on *.* to 'root'@'%' identified by 'kdm001' with grant option;
mysql> Grant all privileges on *.* to 'root'@'localhost' identified by 'kdm001' with grant option;
%表示是所有的外部机器,如果指定某一台机,就将%改为相应的机器名;‘root’则是指要使用的用户名,以上两个用户有相同的用户名和密码,两个用户均为超级用户账号,具有完全的权限可以做任何事情。一个账户(‘root'@'localhost')只用于从本机连接时,另一个账户('root'@'%')可用于从其它主机连接。注意一下,当有多个用户名相同,但密码不同,使用该用户连接时,可能会发生错误,尤其在用于远程连接时!!!
mysql> flush privileges;
(运行此句才生效,或者重启MySQL)
补充,查看所有用户,密码,登录主机所用命令:
select host,user,password from mysql.user;
删除用户指令:
drop user mingzi;
1.3 用户登录
shell>mysql -uroot -pguess db_name; //-p选项后面和密码之间不能有空格 最后面是所使用的数据库
shell>mysql -uroot -p db_name; //此方法较安全
shell>mysql -h xxx.xxx.xxx.xxx -utest -pguess;//用于远程用户登录,注意,远程登录的mysqo需要配置权限。
2、创建并选择数据库:
如果管理员在设置权限时为你创建了数据库,你可以开始使用它。否则,你需要自己创建数据库:
在Unix下,数据库名称是区分大小写的(不像SQL关键字),因此你必须总是以menagerie访问数据库,而不能用Menagerie、MENAGERIE或其它一些变量。对表名也是这样的。(在Windows下,该限制不适用,尽管你必须在一个给定的查询中使用同样的大小写来引用数据库和表。但是,由于多种原因,作为最好的惯例,一定要使用与数据库创建时的同样的大小写。)mysql> CREATE DATABASE menagerie;
创建数据库并不表示选定并使用它,你必须明确地操作。为了使menagerie成为当前的数据库,使用这个命令:
mysql> USE menagerie
Database changed
数据库只需要创建一次,但是必须在每次启动
mysql会话时在使用前先选择它。你可以根据上面的例子执行一个
USE语句来实现。还可以在调用
mysql时,通过命令行选择数据库,只需要在提供连接参数之后指定数据库名称。例如:
shell> mysql -h host -u user -p menagerie
Enter password: ********
注意,刚才显示的命令行中的
menagerie
不是你的 密码。如果你想要在命令行上在
-p选项后提供 密码,则不能插入空格
(例如,如
-pmypassword,不是
-p mypassword
)。但是,不建议在命令行输入密码,因为这样会暴露 密码,能被在机器上登录的其它用户窥探到。
3、创建表:
创建数据库是很容易的部分,但是在这时它是空的,正如SHOW TABLES将告诉你的:
mysql> SHOW TABLES;
Empty set (0.00 sec)
较难的部分是决定你的数据库结构应该是什么:你需要什么数据库表,各数据库表中有什么样的列。
你将需要一个包含你每个宠物的记录的表。它可称为pet表,并且它应该包含,最少,每个动物的名字。因为名字本身不是很有趣,表应该包含另外的信息。例如,如果在你豢养宠物的家庭有超过一个人,你可能想要列出每个动物的主人。你可能也想要记录例如种类和性别的一些基本的描述信息。
年龄呢?那可能有趣,但是存储到一个数据库中不是一件好事情。年龄随着时间流逝而变化,这意味着你将要不断地更新你的记录。相反, 存储一个固定值例如生日比较好,那么,无论何时你需要年龄,可以以当前日期和出生日期之间的差来计算它。MySQL提供了日期运算函数,因此这并不困难。存储出生日期而非年龄还有其它优点:
· 你可以使用数据库完成这样的任务,例如生成即将到来的宠物生日的提示。(如果你认为这类查询有点蠢,注意,这与从商务数据库来识别出不久要发给生日祝贺的客户是同一个问题,因为计算机帮助私人联络。)
· 你可以相对于日期而不止是当前日期来计算年龄。例如,如果你在数据库存储死亡日期,你能很容易地计算出一只宠物死时有多大。
你可能想到pet表中其它有用的其它类型信息,但是到目前为止这些已经足够了:名字、主人、种类,性别、出生和死亡日期。
使用一个CREATE TABLE语句指定你的数据库表的布局:
mysql> CREATE TABLE pet (name VARCHAR(20), owner VARCHAR(20),
-> species VARCHAR(20), sex CHAR(1), birth DATE, death DATE);
VARCHAR适合于
name、
owner和
species列,因为列值是变长的。这些列的长度不必都相同,而且不必是
20。你可以挑选从
1到
65535的任何长度,从中选择一个最合理的值。(如果选择得不合适,后来证明你需要一个更长的字段,
MySQL提供一个
ALTER TABLE语句。)
可以用多种类型的值来表示动物记录中的性别,例如,"m"和"f",或"male"和"female"。使用单字符"m"和"f"是最简单的方法。
很显然,birth和death列应选用DATE数据类。
创建了数据库表后,SHOW TABLES应该产生一些输出:
+---------------------+mysql> SHOW TABLES;
| Tables in menagerie |
+---------------------+
| pet |
+---------------------+
为了验证你的表是按你期望的方式创建,使用一个DESCRIBE语句:
+---------+-------------+------+-----+---------+-------+mysql> DESCRIBE pet;
| Field | Type | Null | Key | Default | Extra |
+---------+-------------+------+-----+---------+-------+
| name | varchar(20) | YES | | NULL | |
| owner | varchar(20) | YES | | NULL | |
| species | varchar(20) | YES | | NULL | |
| sex | char(1) | YES | | NULL | |
| birth | date | YES | | NULL | |
| death | date | YES | | NULL | |
+---------+-------------+------+-----+---------+-------+
你可以随时使用DESCRIBE table_name,例如,如果你忘记表中的列的名称或类型时。
4、将数据载入表中:
创建表后,需要填入内容。通过LOAD DATA和INSERT语句可以完成该任务。
假定你的宠物纪录描述如下。(假定在MySQL中期望的日期格式是YYYY-MM-DD;这可能与你习惯的不同。)
name | owner | species | sex | birth | death |
Fluffy | Harold | cat | f | 1993-02-04 | |
Claws | Gwen | cat | m | 1994-03-17 | |
Buffy | Harold | dog | f | 1989-05-13 | |
Fang | Benny | dog | m | 1990-08-27 | |
Bowser | Diane | dog | m | 1979-08-31 | 1995-07-29 |
Chirpy | Gwen | bird | f | 1998-09-11 | |
Whistler | Gwen | bird | 1997-12-09 | ||
Slim | Benny | snake | m | 1996-04-29 |
因为你是从一个空表开始的,填充它的一个简易方法是创建一个文本文件,每个动物各一行,然后用一个语句将文件的内容装载到表中。
你可以创建一个文本文件“pet.txt”,每行包含一个记录,用定位符(tab)把值分开,并且以CREATE TABLE语句中列出的列次序给出。对于丢失的值(例如未知的性别,或仍然活着的动物的死亡日期),你可以使用NULL值。为了在你的文本文件中表示这些内容,使用\N(反斜线,字母N)。例如,Whistler鸟的记录应为(这里值之间的空白是一个定位符):
name | owner | species | sex | birth | death |
Whistler | Gwen | bird | \N | 1997-12-09 | \N |
要想将文本文件“pet.txt”装载到pet表中,使用这个命令:
请注意如果用Windows中的编辑器(使用\r\n做为行的结束符)创建文件,应使用:mysql> LOAD DATA LOCAL INFILE '/path/pet.txt' INTO TABLE pet;
mysql> LOAD DATA LOCAL INFILE '/path/pet.txt' INTO TABLE pet
-> LINES TERMINATED BY '\r\n';
(在运行
OS X的
Apple机上,应使用行结束符
'\r'。)
如果你愿意,你能明确地在LOAD DATA语句中指出列值的分隔符和行尾标记,但是默认标记是定位符和换行符。这对读入文件“pet.txt”的语句已经足够。
如果想要一次增加一个新记录,可以使用INSERT语句。最简单的形式是,提供每一列的值,其顺序与CREATE TABLE语句中列的顺序相同。假定Diane把一只新仓鼠命名为Puffball,你可以使用下面的INSERT语句添加一条新记录:
mysql> INSERT INTO pet
-> VALUES ('Puffball','Diane','hamster','f','1999-03-30',NULL);
注意,这里字符串和日期值均为引号扩起来的字符串。另外,可以直接用INSERT语句插入NULL代表不存在的值。不能使用LOAD DATA中所示的的\N。
5、数据库的导入导出
5.1 备份数据库(windows)
注意:都是在shell界面下实现的,无需登录MySQL
1.导出整个数据库
mysqldump -u 用户名 -p 数据库名 > 导出的文件名
mysqldump -u root -p yyy> yyy.sql //可以指定导出文件的位置 yyy.sql 换为 D:\yyy.sql
该方法可以远程备份,且对所有存储引擎都适用。(mysqldump –h localhost -u root -p yyy> yyy.sql)
2.导出一个表
mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名
mysqldump -u aiker -p yyy aaa> yyy.sql
3.导出一个数据库结构mysqldump -u root -p -d --add-drop-table yyy>yyy.sql //-d参数是表示只导出结构 --add-drop-table 是在create语句前加drop table 语句
5.2 导入数据库(windows)
注意:在shell下运行,数据库必须之前存在,不会自动创建
1. 导入数据到数据库
mysql -uroot -p -D数据库名 <D:\ yyy.sql //如果数据库中没有表,则自动创建
2. 导入数据到数据库中得某个表
mysql -uroot -p -D数据库名 表名<D:\yyy.sql //数据库中的表的结构应与yyy.sql结构一样
6、查询语句
SELECT 列名称 FROM 表名称
SELECT LastName,FirstName FROM Persons //举例
SELECT * FROM 表名称
7、删除行,表,数据库
删除行:
DELETE FROM 表名称 WHERE 列名称 = 值 DELETE FROM Person WHERE LastName = 'Wilson' //例子
删除表:
DROP TABLE 表名称
删除数据库:
DROP DATABASE 数据库名称
8、设置主键
alter table WebMapTable add primary key(TargetPort) //注意字段必须是int
9、设置索引
create index suoyin on WebMapTable(MapID)
更多内容:点击打开链接