zoukankan      html  css  js  c++  java
  • PHP的MySQL扩展:PHP访问MySQL的常用扩展函数

    来源:http://www.ido321.com/1024.html

    一、PHP连接数据库及基本操作

            MySQL采用的是’客户机/服务器’架构。使用PHP安装的MySQL扩展函数,和直接使用客户端软件区访问MySQL数据库服务器,原理一样,都需要向MySQL管理系统发送SQL命令,然后将结果返回给用户。

            在PHP中,SQL分为两类(查看SQL语句分类):一是有返回结果集的DQL语句,如select/desc 表名,执行完毕之后,需要PHP处理结果集;二是没有结果集的,如DML、DDL等,但是DML语句执行成功后对数据表的记录有影响。

    <?php
    //连接数据库,常用参数是主机名、用户名和密码
    $link = mysql_connect('localhost','root','123456');
    //判断是否连接成功
    if(!$link)
    {
    die('连接失败'.mysql.error());  //连接成功返回资源标识符,失败返回false,mysql_error显示错误信息
    }
    
    //选择数据库,mysql_error()只在调试中使用,再部署项目时就不要了,不然会泄露数据库信息
    mysql_select_db('test') or die('选择数据库失败'.mysql_error());
    
    //mysql_query()可以设置字符集和执行SQL语句
    mysql_query('set names utf-8');
    $sql = 'insert into test(id,name) values("1","dwqs")';
    $result = mysql_query($sql);   //执行sql返回结果集
    
    //处理结果集,insert属于DML,会对表的记录有影响
    if($result && mysql_affected_rows() > 0)
    {
    //mysql_insert_id()返回最后一条新纪录的auto_increment值
    echo '插入数据成功'.mysql_insert_id().'<br/>';
    }
    else
    {
    echo '插入数据失败,错误号:'.mysql_errno().'错误信息:'.mysql_error().'<br/>';
    }
    
    //关闭连接
    mysql_close($link);
    ?>

     

    二、PHP处理select查询结果集

           在PHP中执行select语句返回一个结果集,可以用于对各个字段的处理

    $result  = mysql_query('select * from test');
    //获取记录行的个数
    $rows = mysql_num_rows($result);
    //获取字段个数,即数据列
    $cols = mysql_num_fields($result);

           如果需要访问结果集中的数据,可以使用下列四个函数中的一个(均以结果集资源符作为参数,并自动返回下一条记录,在表末尾时返回false)

                1、mysql_fetch_row():该函数将一条结果记录返回并以一个普通的索引数据保存

                2、mysql_fetch_assoc():从结果集中取得一行作为关联数据保存

                3、mysql_fetch_array():从结果集中取得一行作为关联数组,或数字数组,或二者兼有。可以使用MYSQL_ASSOC(关联数组形 式)、MYSQL_NUM(索引数组形式)和MYSQL_BOTH作为第二个参数,指定返回的数据形态。

                4、mysql_fetch_object():从结果集中取得一行作为对象,各个字段以对象方式访问。

          建议:没有特殊要求,不要使用mysql_fetch_array(),可以使用mysql_fetch_row()或者mysql_fetch_assoc()实现同样的功能,且效率高。

          另外也有三个与结果集相关的常用函数

                5、mysql_data_seek(int $num):移动内部结果的指针,$num是想要设定的新的结果集指针的行数。

                6、mysql_fetch_lengths(resource $result):取得结果集中每个输出的长度

                7、mysql_result(resource $result , int $row[,mixed $field]):返回 MySQL 结果集中一个单元的内容。字段参数可以是字段的偏移量或者字段名,或者是字段表点字段名(tablename.fieldname)。如果给列起了别名(’select foo as bar from…’),则用别名替代列名。调用 mysql_result()不能和其它处理结果集的函数混合调用。

     

    下一篇:如何利用WordPress创建自定义注册表单插件


  • 相关阅读:
    1033.采药1
    G——胜利大逃亡 (BFS)
    POJ 3278 Catch That Cow
    C
    11.17 dfs poj1979 Red and Black
    11.11反思
    kmp笔记
    dfs bfs
    1113
    python 类方法
  • 原文地址:https://www.cnblogs.com/ido321/p/4028574.html
Copyright © 2011-2022 走看看