新鲜、有趣,互联生活。令狐葱。

2007/07/22

PHP操作数据库详解(一)

1. 建立和关闭连接byLinghucong

1) mysql_connect()
    resource mysql_connect([string hostname [:port][:/path/to/socket][,string username] [,string password]])
    所有参数都是可选的
    举例:
    @mysql_connect("localhost", "webuser", "password")
    or die("Could not connect to mysql server!");
    注意,@符号表示禁止失败尝试导致的任何错误信息,用户将看到的是die()中指定的错误信息.
    
    注意,当与多个mysql进行连接时,必须指定每个连接的链接ID,如下:
    $link1 = @mysql_connect("server1", "webuser", "password")
    or die("Could not connect to mysql server!");
    $link2 = @mysql_connect("server2", "webuser", "password")
    or die("Could not connect to mysql server!");

2) mysql_pconnect()
   resource mysql_pconnect([string hostname [:port][:/path/to/socket][,string username] [,string password]])
    与mysql_connect()不同的是:会首先查找现有链接,不存在时才创建.
    注意,不需要显示关闭连接(mysql_close()),因为连接将放在池中,所以叫持久连接.

3) mysql_close()
    boolean mysql_close([resource link_id])
    关闭连接不是必须的,因为可以由mysql的垃圾回收来处理.
    如果没有指定link_id,则关闭最近的链接.
    
2. 选择数据库 byLinghucong
    mysql_select_db()
    boolean mysql_select_db(string db_name [, resource link_id])

3. 查询MySql

1) mysql_query()
    resource mysql_query(string query [,resource link_id])
    负责执行query.

2) mysql_db_query()
    resource mysql_db_query(string database, string query [, resource link_id])
    等价于mysql_select_db() + mysql_query(),从参数中就可以清楚的看出来.
    
4. 获取和显示数据 byLinghucong

1) mysql_result()
    mixed mysql_result(resource result_set, int row [,mixed field])
    从result_set 的指定row 中获取一个field 的数据. 简单但是效率低.
    
    举例:
    $link1 = @mysql_connect("server1", "webuser", "password")
    or die("Could not connect to mysql server!");
    @mysql_select_db("company") or die("Could not select database!");
    
    $query = "select id, name from product order by name";
    $result = mysql_query($query);
    $id = mysql_result($result, 0, "id");
    $name = mysql_result($result, 0, "name");
    
    mysql_close(); byLinghucong
    
    注意,上述代码只是输出结果集中的第一条数据的字段值,如果要输出所有记录,需要循环处理.
    ...
    for ($i = 0; $i <= mysql_num_rows($result); $i++)
    {
        $id = mysql_result($result, 0, "id");
        $name = mysql_result($result, 0, "name");
        echo "Product: $name ($id)";
    }
    ...
    
    注意,如果查询字段名是别名,则mysql_result中就使用别名.byLinghucong

2) mysql_fetch_row()
    array mysql_fetch_row(resource result_set)
    从result_set中获取整行,把数据放入数组中.
    举例(注意和list 的巧妙配合):
    ...
    $query = "select id, name from product order by name";
    $result = mysql_query($query);
    while(list($id, $name) = mysql_fetch_row($result)) {
        echo "Product: $name ($id)";
    }
    ...
    
3) mysql_fetch_array() byLinghucong
    array mysql_fetch_array(resource result_set [,int result_type])
    mysql_fetch_row()的增强版.
    将result_set的每一行获取为一个关联数组或/和数值索引数组.
    默认获取两种数组,result_type可以设置:
    MYSQL_ASSOC:返回关联数组,字段名=>字段值
    MYSQL_NUM:返回数值索引数组.
    MYSQL_BOTH:获取两种数组.因此每个字段可以按索引偏移引用,也可以按字段名引用.
    举例:
    ...
    $query = "select id, name from product order by name";
    $result = mysql_query($query);
    while($row = mysql_fetch_array($result, MYSQL_BOTH)) {
        $name = $row['name'];//或者 $name = $row[1];
        $name = $row['id'];//或者 $name = $row[0];
        echo "Product: $name ($id)";
    }
    ... byLinghucong
    
4) mysql_fetch_assoc()
    array mysql_fetch_assoc(resource result_set)
    相当于 mysql_fetch_array($result, MYSQL_ASSOC)
    
5) mysql_fetch_object()
    object mysql_fetch_object(resource result_set)
    和mysql_fetch_array()功能一样,不过返回的不是数组,而是一个对象.
    举例:
    ...byLinghucong
    $query = "select id, name from product order by name";
    $result = mysql_query($query);
    while($row = mysql_fetch_object($result)) {
        $name = $row->name;
        $name = $row->id;
        echo "Product: $name ($id)";
    }
    ...
    
5. 所选择的记录和受影响的记录 byLinghucongbyLinghucong

1) mysql_num_rows()
    int mysql_num_rows(resource result_set)
    返回result_set中的行数.
    注意,mysql_num_rows()只在确定select语句查询获得的记录数有效,如果要获取insert/updata/delete查询影响的记录数,需要使用mysql_affected_rows().

2) mysql_affected_rows()
    int mysql_affected_rows([resource link_id])
    获取insert/updata/delete查询影响的记录数
    注意,不需要输入参数,默认使用最近建立的数据库连接的最近结果.可以使用可选参数link_id来选择数据库连接.
    
6. 获取数据库和表的信息
1) mysql_list_dbs() byLinghucong
    resource mysql_list_dbs([resource link_id])
    获取服务器上所有数据库名称.
    举例:
    mysql_connect("localhost", "name","pwd");
    $dbs = mysql_list_dbs();
    while (list($db) = mysql_fetch_row(dbs)) {
        echo "$db <br>";
    }
    注意,输出结果与使用的用户权限相关.

2) mysql_db_name() byLinghucong
    string mysql_db_name(resource result_set, interger index)
    获取在mysql_list_dbs()返回的result_set中位置为index的数据库名.
    
3) mysql_list_tables()
    resource mysql_list_tables(string database [,resource link_id])
    获取database中的所有表名.
byLinghucong
4) mysql_tablename()
    string mysql_tablename(resource result_set, interger index)
    获取mysql_list_tables()返回的result_set中位置为index的表名.

没有评论: