从入门到精通---初学PHP和MySQL一

发表于:2007-06-21来源:作者:点击数: 标签:
这是一个基本的教程。没有怪异的代码,只是一些基

   
  这是一个基本的教程。没有怪异的代码,只是一些基础。现在有大量的教程是基于UNIX机器的,这个教程将集中在基于Windows平台上。然而,除了安装部分,有或多或少的针对于Windows的说明外,其它部分对所有的平台都是一样的。顺便说一下,关于安装部分,请看本站的安装指南。

在这个教程中,我们将一步一步地建立一个小的网站,使用了PHPMySQL的下面特性:
  1. 查看数据库
  2. 编辑数据库的记录;
  3. 修改数据库的记录;
  4. 删除数据库的记录。
  
  我们将同时学习MySQL和PHP,一起去感觉它们。先运行web服务器(已增加PHP扩展); 运行MySQL。
  
  创建和操纵一个MySQL数据库:
  
  首先我们需要创建要使用的数据库和表。数据库起名为"example",表名为"tbl",有以下字段:识别号,名,姓和信息。要通过mysql终端完成建库和定义表的工作,只要双击或运行c:\mysql\bin\mysql.exe。
  如果要看在MySQL中已经定义了哪些表,可以使用(注意mysql>是终端提示符):
  Mysql> show databases; <回车>
  这个命令可能显示如下信息:
  +----------+
  | Database |
  +----------+
  | mysql |
  | test |
  +----------+
  2 rows in set (0.01 sec)
  为了定义一个新的数据库(example),键入:
  Mysql> create database example; <回车>
  你将会看到一个回答,如:
  Query OK, 1 row affected (0.17 sec)很发,我们现在有了一个新数据库了。现在我们可以在库中建立一个新表,但首先我们需要先选中新的数据库:
  Mysql> use example; <回车>
  
  回答应该是:
  Database changed
  现在我们可以建表了,有如下字段:
  
  索引号 - 整数
  用户名 - 最大长度为30的字符串
  用户姓 - 最大长度为50的字符串
  自由信息 - 最大长度为100的字符串
  在MySQL提示符下键入下面的命令来创建表:
  MySQL> create table tbl (idx integer(3), UserName varchar(30), LastName varchar(50), FreeText varchar(100));<回车>
  
  回答应该是:
  Query OK, 0 rows affected (0.01 sec)
  好,让我们看一下从MySQL提示符下看表是什么样子的,键入命令:
  MySQL> show columns from tbl; <回车>
  我们将得到下面的结果:
  +----------+--------------+------+-----+---------+-------+
  | Field | Type | Null | Key | Default | Extra |
  +----------+--------------+------+-----+---------+-------+
  | idx | int(3) | YES | | NULL | |
  | UserName | varchar(30) | YES | | NULL | |
  | LastName | varchar(50) | YES | | NULL | |
  | FreeText | varchar(100) | YES | | NULL | |
  +----------+--------------+------+-----+---------+-------+
  4 rows in set (0.00 sec)
  在这里,我们可以看到刚创建的表"tbl"的内容。
  
  现在让我们看一下表中有什么内容。键入下面的命令:
  MySQL> select * from tbl;<回车>
  
  这个命令是用来显示表"tbl"中的所有数据的。输出可能是:
  Empty set (0.07 sec)之所以得到这个结果,是因为我们还没有在表中插入任何数据。让我们往表中插入一些数据,键入:
  MySQL> insert into tbl values (1,'Rafi','Ton','Just a test');<回车>
  
  Query OK, 1 row affected (0.04 sec)
  如上所见,我们插入到表中的值是按照前面我们定义表的顺序,因为使用的是缺省的顺序。我们可以设定数据的顺序,语法如下:
  MySQL> insert into tbl (idx,UserName,LastName,FreeText) values (1,'Rafi','Ton','Just a test');<回车>
  
  好,现在我们可以再看一下表中的内容:
  
  MySQL> select * from tbl;<回车>
  这次的结果是:
  +------+----------+----------+-------------+
  | idx | UserName | LastName | FreeText |
  +------+----------+----------+-------------+
  | 1 | Rafi | Ton | Just a test |
  +------+----------+----------+-------------+
  1 row in set (0.00 sec)
  现在我们可以看到表的结构和每一个单元格的内容。
  
  现在我们想删除数据。为了实现我们应该键入:
  
  MySQL> delete from tbl where idx=1 limit 1;<回车> Query OK, 1 row affected (0.00 sec)
  
  好,给出一些解释。我们正在告诉MySQL从"tbl"表中删除记录,删除那些idx字段值为1的记录,并且只限制删除一条记录。如果我们不限制删除记录数为1,那么所有idx为1的记录都将被删除(在这个例子中我们只有一条记录,但是虽然如此,我只是想让这一点更加清楚)。
  
  不幸的是,我们又一次得到了一个空表,所以让我们再输进去:
  
  MySQL> insert into tbl values (1,'Rafi','Ton','Just a test');<回车>
  Query OK, 1 row affected (0.04 sec)
  
  另一件可以做的事是,修改指定字段的内容,使用"update"命令:
  
  MySQL>update tbl set UserName='Berber' where UserName='Rafi';<回车>
  Query OK, 1 row affected (0.01 sec)
  Rows matched: 1 Changed: 1 Warnings: 0
  
  这个命令将搜索所有UserName为"Rafi"的记录,并将它改为"Berber"。注意,set部分和where部分不一定要一样。我们可以索搜一个字段但是改变另一个字段。而且,我们可以执行两个或更多条件的搜索。
  
  MySQL>update tbl set UserName='Rafi' where UserName='Berber' and LastName='Ton';<回车>
  Query OK, 1 row affected (0.04 sec)
  
  这个查询搜索了两个字段,改变了UserName的值

原文转自:http://www.ltesting.net