|
资源类型 在 MySQL 模块中使用了两种资源类型。第一种是数据库的连接句柄,第二种是 SQL 查询返回的结果集。
预定义常量 以下常量由本扩展模块定义,因此只有在本扩展模块被编译到 PHP 中,或者在运行时被动态加载后才有效。
在 PHP 4.3.0 以后的版本中,允许在 mysql_connect() 函数和 mysql_pconnect() 函数中指定更多的客户端标记。下面列出所定义的常量:
表格 2. MySQL 客户端常量
常量 描述 MYSQL_CLIENT_COMPRESS 使用压缩的通讯协议 MYSQL_CLIENT_IGNORE_SPACE 允许在函数名后留空格位 MYSQL_CLIENT_INTERACTIVE 允许设置断开连接之前所空闲等候的 interactive_timeout 时间(代替 wait_timeout)。 MYSQL_CLIENT_SSL 使用 SSL 加密。本标志仅在 MySQL 客户端库版本为 4.x 或更高版本时可用。在 PHP 4 和 Windows 版的 PHP 5 安装包中绑定的都是 3.23.x。
mysql_fetch_array() 函数使用一个常量来表示所返回数组的类型。下面是常量的定义:
表格 3. MySQL fetch 常量
常量 描述 MYSQL_ASSOC 返回的数据列使用字段名作为数组的索引名。 MYSQL_BOTH 返回的数据列使用字段名及数字索引作为数组的索引名。 MYSQL_NUM 返回的数据列使用数字索引作为数组的索引名。索引从 0 开始,表示返回结果的第一个字段。
注释 注: 大多数 MySQL 函数都接受 link_identifier 作为最后一个可选参数。如果未提供此参数,则使用最后一个打开的连接。如果不存在连接,则会用 php.ini 中定义的默认参数去尝试建立连接。如果连接不成功,函数返回 FALSE。
范例 下面的简单例子演示如何连接数据库,执行查询语句,打印返回结果集和断开数据库等一系列基本的 MySQL 操作。 例子 1. MySQL 例子
<?php // 连接,选择数据库 $link = mysql_connect('mysql_host', 'mysql_user', 'mysql_password') or die('Could not connect: ' . mysql_error()); echo 'Connected successfully'; mysql_select_db('my_database') or die('Could not select database');
// 执行 SQL 查询 $query = 'Select * FROM my_table'; $result = mysql_query($query) or die('Query failed: ' . mysql_error());
// 用 HTML 显示结果 echo "<table>\n"; while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) { echo "\t<tr>\n"; foreach ($line as $col_value) { echo "\t\t<td>$col_value</td>\n"; } echo "\t</tr>\n"; } echo "</table>\n";
// 释放结果集 mysql_free_result($result);
// 关闭连接 mysql_close($link); ?>
目录 mysql_affected_rows -- 取得前一次 MySQL 操作所影响的记录行数 mysql_change_user -- 改变活动连接中登录的用户 mysql_client_encoding -- 返回字符集的名称 mysql_close -- 关闭 MySQL 连接 mysql_connect -- 打开一个到 MySQL 服务器的连接 mysql_create_db -- 新建一个 MySQL 数据库 mysql_data_seek -- 移动内部结果的指针 mysql_db_name -- 取得结果数据 mysql_db_query -- 发送一条 MySQL 查询 mysql_drop_db -- 丢弃(删除)一个 MySQL 数据库 mysql_errno -- 返回上一个 MySQL 操作中的错误信息的数字编码 mysql_error -- 返回上一个 MySQL 操作产生的文本错误信息 mysql_escape_string -- 转义一个字符串用于 mysql_query mysql_fetch_array -- 从结果集中取得一行作为关联数组,或数字数组,或二者兼有 mysql_fetch_assoc -- 从结果集中取得一行作为关联数组 mysql_fetch_field -- 从结果集中取得列信息并作为对象返回 mysql_fetch_lengths -- 取得结果集中每个输出的长度 mysql_fetch_object -- 从结果集中取得一行作为对象 mysql_fetch_row -- 从结果集中取得一行作为枚举数组 mysql_field_flags -- 从结果中取得和指定字段关联的标志 mysql_field_len -- 返回指定字段的长度 mysql_field_name -- 取得结果中指定字段的字段名 mysql_field_seek -- 将结果集中的指针设定为制定的字段偏移量 mysql_field_table -- 取得指定字段所在的表名 mysql_field_type -- 取得结果集中指定字段的类型 mysql_free_result -- 释放结果内存 mysql_get_client_info -- 取得 MySQL 客户端信息 mysql_get_host_info -- 取得 MySQL 主机信息 mysql_get_proto_info -- 取得 MySQL 协议信息 mysql_get_server_info -- 取得 MySQL 服务器信息 mysql_info -- 取得最近一条查询的信息 mysql_insert_id -- 取得上一步 Insert 操作产生的 ID mysql_list_dbs -- 列出 MySQL 服务器中所有的数据库 mysql_list_fields -- 列出 MySQL 结果中的字段 mysql_list_processes -- 列出 MySQL 进程 mysql_list_tables -- 列出 MySQL 数据库中的表 mysql_num_fields -- 取得结果集中字段的数目 mysql_num_rows -- 取得结果集中行的数目 mysql_pconnect -- 打开一个到 MySQL 服务器的持久连接 mysql_ping -- Ping 一个服务器连接,如果没有连接则重新连接 mysql_query -- 发送一条 MySQL 查询 mysql_real_escape_string -- 转义 SQL 语句中使用的字符串中的特殊字符,并考虑到连接的当前字符集 mysql_result -- 取得结果数据 mysql_select_db -- 选择 MySQL 数据库 mysql_stat -- 取得当前系统状态 mysql_tablename -- 取得表名 mysql_thread_id -- 返回当前线程的 ID mysql_unbuffered_query -- 向 MySQL 发送一条 SQL 查询,并不获取和缓存结果的行
|
|