首页 服务器正文

初学入门PHP和MySQL(2)

mydiannao 服务器 09-12 4748 0

  第二部分 - 创建和操纵一个 MySQL 数据库

  首先我们需要创建要使用的数据库和表。数据库起名为“example“,表名为“tbl“,有以下字段:识别号,名,姓和信息。要通过mysql终端完成建库和定义表的工作,只要双击或运行c:mysqlbinmysql.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的值。

本站公告

【企业、公司、工作室、出租屋、家庭】
远程解决:网络异常,路由器配置,打印机设置,驱动安装,局域网文件共享,监控调试,电脑故障等电脑周边问题解决,欢迎咨询!
微信:1633694989