mysql新手指南

李雅普诺夫 贡献于2016-12-04

作者 AutoBVT  创建于2016-05-13 13:31:00   修改者AutoBVT  修改于2016-05-13 13:41:00字数6720

文档摘要:
关键词:

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,然后键入以下命令 (password 里面不要加命令符) mysqladmin -uroot password ab12  注:因为开始时root没有密码,所以-p旧密码一项就可以省略了。  2、例2:再将root的密码改为djg345。  mysqladmin -uroot -pab12 password djg345 三、增加新用户。(注意:和上面不同,下面的因为是MYSQL环境中的命令,所以后面都带一个分号作为命令结束符)  格式:grant select on 数据库.* to 用户名@登录主机 identified by "密码"  例1、增加一个用户test1密码为abc,让他可以在任何主机上登录,并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入MYSQL,然后键入以下命令:  grant select,insert,update,delete on *.* to test1@"%" Identified by "abc";  但例1增加的用户是十分危险的,你想如某个人知道test1的密码,那么他就可以在internet上的任何一台电脑上登录你的mysql数据库并对你的数据可以为所欲为了,解决办法见例2。  例2、增加一个用户test2密码为abc,让他只可以在localhost上登录,并可以对数据库mydb进行查询、插入、修改、删除的操作(localhost指本地主机,即MYSQL数据库所在的那台主机),这样用户即使用知道test2的密码,他也无法从internet上直接访问数据库,只能通过 MYSQL主机上的web页来访问了。  grant select,insert,update,delete on mydb.* to test2@localhost identified by "abc";  如果你不想test2有密码,可以再打一个命令将密码消掉。  grant select,insert,update,delete on mydb.* to test2@localhost identified by ""; 在上篇我们讲了登录、增加用户、密码更改等问题。下篇我们来看看MYSQL中有关数据库方面的操作。注意:你必须首先登录到MYSQL中,以下操作都是在MYSQL的提示符下进行的,而且每个命令以分号结束。 一、操作技巧  1、如果你打命令时,回车后发现忘记加分号,你无须重打一遍命令,只要打个分号回车就可以了。也就是说你可以把一个完整的命令分成几行来打,完后用分号作结束标志就OK。  2、你可以使用光标上下键调出以前的命令。但以前我用过的一个MYSQL旧版本不支持。我现在用的是mysql-3.23.27-beta-win。 二、显示命令  1、显示数据库列表。  show databases;  刚开始时才两个数据库:mysql和test。mysql库很重要它里面有MYSQL的系统信息,我们改密码和新增用户,实际上就是用这个库进行操作。 2、显示库中的数据表:  use mysql; //打开库,学过FOXBASE的一定不会陌生吧  show tables;  3、显示数据表的结构:  describe 表名;  4、建库:  create database 库名;  5、建表:  use 库名;  create table 表名 (字段设定列表);  6、删库和删表:  drop database 库名;  drop table 表名;  7、将表中记录清空:  delete from 表名;  8、显示表中的记录:  select * from 表名; 三、一个建库和建表以及插入数据的实例  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的字符字段,而且缺省值为深圳。varchar和char有什么区别呢,只有等以后的文章再说了。 (4)将YEAR设为日期字段。  如果你在mysql提示符键入上面的命令也可以,但不方便调试。你可以将以上命令原样写入一个文本文件中假设为school.sql,然后复制到c:\下,并在DOS状态进入目录\mysql\bin,然后键入以下命令:  mysql -uroot -p密码 < c:\school.sql  如果成功,空出一行无任何显示;如有错误,会有提示。(以上命令已经调试,你只要将//的注释去掉即可使用)。 四、将文本数据转到数据库中  1、文本数据应符合的格式:字段数据之间用tab键隔开,null值用\n来代替.  例:  3 rose 深圳二中 1976-10-10  4 mike 深圳一中 1975-12-23  2、数据传入命令 load data local infile "文件名" into table 表名;  注意:你最好将文件复制到\mysql\bin目录下,并且要先用use命令打表所在的库 。 五、备份数据库:(命令在DOS的\mysql\bin目录下执行)  mysqldump --opt school>school.bbb  注释:将数据库school备份到school.bbb文件,school.bbb是一个文本文件,文件名任取,打开看看你会有新发现。 以下为初级手册 数据类型和数据表    从本质上说,数据库就是一种不断增长的复杂的数据组织结构。在mysql数据库中,用于保存数据记录的结构被称为数据表。而每一条数据记录则是由更小的数据对象,即数据类型组成。因此,总体来说,一个或多个数据类型组成一条数据记录,一条或多条数据记录组成一个数据表,一个或多个数据表组成一个数据库。我们可以把上述结构理解为如下形式:  database $#@60; table $#@60; record $#@60; datatype    数据类型分为不同的格式和大小,可以方便数据库的设计人员创建最理想的数据结构。能否正确的选择恰当的数据类型对最终数据库的性能具有重要的影响,因此,我们有必要首先对数据类型的有关概念进行较为详细的介绍。  mysql 数据类型    mysql 数据库提供了多种数据类型,其中较为常用的几种如下:  char (m)    char数据类型用于表示固定长度的字符串,可以包含最多达255个字符。其中m代表字符串的长度。  举例如下:  car_model char(10);  varchar (m)    varchar是一种比char更加灵活的数据类型,同样用于表示字符数据,但是varchar可以保存可变长度的字符串。其中m代表该数据类型所允许保存的字符串的最大长度,只要长度小于该最大值的字符串都可以被保存在该数据类型中。因此,对于那些难以估计确切长度的数据对象来说,使用varchar数据类型更加明智。varchar数据类型所支持的最大长度也是 255个字符。    这里需要提醒读者注意的一点是,虽然varchar使用起来较为灵活,但是从整个系统的性能角度来说,char数据类型的处理速度更快,有时甚至可以超出varchar处理速度的50%。因此,用户在设计数据库时应当综合考虑各方面的因素,以求达到最佳的平衡。  举例如下:  car_model varchar(10);  int (m) [unsigned]    int数据类型用于保存从- 2147483647 到2147483648范围之内的任意整数数据。如果用户使用unsigned选项,则有效数据范围调整为0-4294967295。举例如下:  light_years int;    按照上述数据类型的设置,-24567为有效数据,而3000000000则因为超出了有效数据范围成为无效数据。  再例如:  light_years int unsigned;  这时,3000000000成为有效数据,而-24567则成为无效数据。  float [(m,d)]    float数据类型用于表示数值较小的浮点数据,可以提供更加准确的数据精度。其中,m代表浮点数据的长度(即小数点左右数据长度的总和),d表示浮点数据位于小数点右边的数值位数。  举例如下:  rainfall float (4,2);    按照上述数据类型的设置,42.35为有效数据,而324.45和3.542则因为超过数据长度限制或者小数点右边位数大于规定值2成为无效数据。  date    date数据类型用于保存日期数据,默认格式为yyyy-mm-dd。mysql提供了许多功能强大的日期格式化和操作命令,本文无法在此一一进行介绍,感兴趣的读者可以参看mysql的技术文档。  date数据类型举例如下:  the_date date;  text / blob    text和blob数据类型可以用来保存255 到65535个字符,如果用户需要把大段文本保存到数据库内的话,可以选用text或blob数据类型。text和blob这两种数据类型基本相同,唯一的区别在于text不区分大小写,而blob对字符的大小写敏感。  set    set数据类型是多个数据值的组合,任何部分或全部数据值都是该数据类型的有效数据。set数据类型最大可以包含64个指定数据值。  举例如下:  transport set ("truck", "wag not null;    根据上述数据类型的设置,truck、wag  enum    enum数据类型和set基本相同,唯一的区别在于enum只允许选择一个有效数据值。例如:  transport enum ("truck", "wag not null;    根据上述设置,truck或wag    以上,我们只是对用户使用mysql数据库的过程中经常用到的数据类型进行了简单介绍,有兴趣的读者,可以参看mysql技术文档的详细说明。  数据记录    一组经过声明的数据类型就可以组成一条记录。记录小到可以只包含一个数据变量,大到可以满足用户的各种复杂需求。多条记录组合在一起就构成了数据表的基本结构。  数据表    在我们执行各种数据库命令之前,首先需要创建用来保存信息的数据表。我们可以通过以下方式在mysql数据库中创建新的数据表:  mysql$#@62; create table test (  $#@62; name varchar (15),  $#@62; email varchar (25),  $#@62; ph int,  $#@62; id int not null auto_increment,  $#@62; primary key (id));  系统反馈信息为:  query ok, 0 rows affected (0.10 sec)  mysql$#@62;    这样,我们就在数据库中创建了一个新的数据表。注意,同一个数据库中不能存在两个名称相同的数据表。    这里,我们使用create table命令创建的test数据表中包含name,email,ph    下面,我们来看一看创建数据表时所用到的几个主要的参数选项。  primary key    具有primary key限制条件的字段用于区分同一个数据表中的不同记录。因为同一个数据表中不会存在两个具有相同值的primary key字段,所以对于那些需要严格区分不同记录的数据表来说,primary key具有相当重要的作用。  auto_increment    具有auto_increment限制条件的字段值从1开始,每增加一条新记录,值就会相应地增加1。一般来说,我们可以把auto_increment字段作为数据表中每一条记录的标识字段。  not null    not null限制条件规定用户不得在该字段中插入空值。  其它数据表命令    除了创建新的数据表之外,mysql数据库还提供了其它许多非常实用的以数据表作为操作对象的命令。  显示数据表命令  mysql$#@62; show tables;    该命令将会列出当前数据库下的所有数据表。  显示字段命令  mysql$#@62; show columns from tablename;    该命令将会返回指定数据表的所有字段和字段相关信息。  数据操作    对mysql数据库中数据的操作可以划分为四种不同的类型,分别是添加、删除、修改和查询,我们将会在本节中对此进行介绍。但是,首先我们需要强调的一点就是mysql数据库所采用的sql语言同其它绝大多数计算机编程语言一样,对命令的语法格式有严格的规定。任何语法格式上的错误,例如不正确的使用括号、逗号或分号等都可能导致命令执行过程中的错误。因此,建议用户在学习时一定要多留心语法格式的使用。  添加记录    用户可以使用insert命令向数据库中添加新的记录。  例如:  mysql$#@62; insert into test values  mysql$#@62; (john, carrots@mail.com,  mysql$#@62; 5554321, null);    上述命令正确执行后会返回以下信息:  query ok, 1 row affected (0.02 sec)  mysql$#@62;    对上述命令有几点我们需要说明。首先,所有的字符类型数据都必须使用单引号括起来。其次,null关键字与auto_increment限制条件相结合可以为字段自动赋值。最后,也是最重要的一点就是新记录的字段值必须与数据表中的原字段相对应,如果原数据表中有4个字段,而用户所添加的记录包含3个或5个字段的话都会导致错误出现。    mysql数据库的一个非常显著的优势就是可以对整数、字符串和日期数据进行自动转换。因此,用户在添加新记录时就不必担心因为数据类型不相符而出现错误。  查询数据    如果我们无法从数据库中查找和读取数据的话,数据库就丧失了其存在和使用的价值。    在mysql数据库中,用户可以使用select命令进行数据的查询。  例如:  mysql$#@62; select * from test  mysql$#@62; where (name = "john");  上述命令会返回如下结果:  name  email  ph  id  john  carrots@mail.com  5554321  1  删除数据    用户除了可以向数据表中添加新的记录之外,还可以删除数据表中的已有记录。删除记录可以使用delete命令。  例如:  mysql$#@62; delete from test  mysql$#@62; where (name = "");    该命令将会删除test数据表中name字段的值为john的记录。同样,  mysql$#@62; delete from test  mysql$#@62; where (ph = 5554321);    将会从数据表中删除ph  修改数据    mysql数据库还支持用户对已经输入到数据表中的数据进行修改。修改记录可以使用update命令。  例如:  mysql$#@62; update test set name = mary  mysql$#@62; where name = "john";  上述命令的执行结果如下:  name  email  ph  id  mary  carrots@mail.com  5554321  1    到此为止,我们对mysql数据库数据操作的核心概念,即数据的添加、删除、修改和查询进行了简单的介绍。

下载文档到电脑,查找使用更方便

文档的实际排版效果,会与网站的显示效果略有不同!!

需要 10 金币 [ 分享文档获得金币 ] 0 人已下载

下载文档