PHP4 与 MySQL 数据库操作函数详解


Posted in PHP onOctober 09, 2006

I 说PHP就不能不提MySQL,而要讲MySQL,那么PHP也是必然要被提起。PHP的迅速崛起,离不开MySQL,而MySQL的广泛应用,也与PHP休戚相关。  

下面详细分析PHP4中与MySQL相关操作的函数(共32个,开头都为mysql_):  

<1>. 连接数据库服务器(database server)的函数(2个):  

(1).mysql_connect()  
格式:int mysql_connect(string [hostname] [ort],string [username],string [password]);  

参数中的port参数表示数据库服务器的端口号,一般用它的默认端口号就可以了。  
如果不填任何参数,则默认的hostname为localhost,username为root,password为空。  

函数执行成功,返回一个int 类型的连接号(link_identifier),执行失败,返回false值。  

例子:  

$connect = mysql_connect("localhost","user","password");  
if($connect) echo "Connect Successed!"; //连接成功,显示Connect Successed!  
else echo "Connect Failed!"; //连接失败,显示Connect Failed!  

?>  

在上例中,如mysql_connect()执行失败,将显示系统的错误提示,而后继续往下执行。那,该如何屏蔽这些系统的错误提示并在失败后结束程序?  
在MySQL中,允许在数据库函数之前加上@符号,屏蔽系统的错误提示,同时用die()函数给出更易理解的错误提示,然后die()函数将自动退出程序。  

上例可以改为:  

$connect = @mysql_connect("localhost","user","password") or die ("Unable to connect database server!");  

?>  

如mysql_connect()执行失败,将显示 Unable to connect database server!后,退出程序。  

(2).mysql_pconnect()  
格式:int mysql_pconnect(string [hostname] [ort],string [username],string [password]);  
此函数与(1)的mysql_connect()基本相同,区别在于:  

--------- 当数据库操作结束之后 ,由(1)的mysql_connect()建立的连接将自动关闭,而(2)的mysql_pconnect()建立的连接将继续存在,是一种稳固持久的连接。  
--------- 在(2)的mysql_pconnect(),每次连接前,都会检查是否有使用同样的hostname,use,password的连接,如果有,则直接使用这个连接号。  
--------- (1)的mysql_connect()建立的连接可以用mysql_close()关闭,而(2)的mysql_pconnect()不能用mysql_close()来关闭。  

<2>.关闭数据库连接函数(1个):  

mysql_close()  
格式:int mysql_close(int link_identifier);  
关闭由mysql_connect()函数建立的连接,执行成功,返回ture值,失败则返回false值。  

例子如下:  

$connect = @mysql_connect("hostname","user","password") or die("Unable to connect database server!");  

$close = @mysql_close($connect) or die ("Unable to close database server connect!");  

?>  

注:mysql_close()不能关闭由mysql_pconnect()函数建立的连接。  

<3>.选择数据库函数(1个):  

mysql_select_db()  
格式:int mysql_select_db(string database name , int link_identifier);  
选择指定的database name ,成功,返回1个真值(True),失败,则返回1个False值  
例子1:  
$select = mysql_select_db(\'forum\' , $connect);  
if($select)  
{echo "connect db forum successed!";}  
else  
{echo "connect db forum failed!";}  
?>  

例子2:  
$select = mysql_select_db("forum",$connect) or die("Can not connect this DB!");  
?>  

注:此函数相当于在MySQL中的USE语句:如 USE forum  

<4>.SQL查询函数(2个):  

1、mysql_query()  
格式:int mysql_query(string sqlquery , int link_identifier);  
向服务器发一段标准SQL语句请求。如果失败,则返回一False值。  

例子:  
$connect = mysql_connect($hostname,$user,$pwd);  
$select = mysql_select_db($dbname,$connect);  
$query = mysql_query($sql , $connect);  
if($query) echo "Successed !";  
else echo "Failed !";  
?>  
此函数一定要与mysql_select_db()函数配合使用,单独使用它就没有意义了!  

2、mysql_db_query()  
格式:int mysql_db_query(string database , string sqlquery , int link_identifier);  

在此函数中必须指定数据库名database和SQL语句sqlquery,如失败则返回False。  

例子:  

$connect = mysql_connect($hostname , $user , $pwd);  
$query = mysql_db_query($dbname , $sql , $connect);  
if($query) echo "Successed !";  
else echo "Failed !";  
?>  

mysql_db_query()与mysql_query()的区别就在于前者可以不用使用mysql_select_db()来选择数据库database,而在执行SQL语句的同时,进行选择数据库。 <5>.数据库记录操作函数(5个):  

1、mysql_fetch_array()  
格式:array mysql_fetch_array(int query);  

执行成功,返回1个数组,该数组保存有下一条记录的值,如执行失败,则返回False值。  
返回的数组既可以用下标来表示,也可以用字段名来表示。  

例子:  
$query = mysql_query($sql , $connect);  
while($arrary = mysql_fetch_array($query))  
{  

echo $array[column1]." | ".$array[column2];  
//echo $array[0]." | ".$array[1];  

}  
?>  
Note : 数组的下标是从0开始的!  

2、mysql_fetch_row()  
格式:array = mysql_fetch_row(int query);  

与1的mysql_fetch_array()函数功能基本相同。区别在于mysql_fetch_row()只能以数组下标来表示。  
成功返回1个数组,失败返回False值。  

例子:  
$query = mysql_query($sql , $connect);  
while($row = mysql_fetch_row($query))  
{  
echo $row[0] . " | " . $row[1] . "
";  
}  
?>  
Note : mysql_fetch_row()函数只能用数组下标来表示,并从0开始。  
另:mysql_fetch_row()比mysql_fetch_array()执行速度快,并且都是对下一行数据进行读取。  

3、mysql_result()  
格式:int mysql_result(int query , int row , string filedname);  

在mysql_result()中,参数row必须从0开始,参数filedname必须是真实的字段名,不能用下标来表示。  
执行成功,返回由数据库中取出的字段的数值,失败则返回False值。  

例子:  
$query = mysql_query($sql , $connect);  
echo mysql_result($query , 0 , "column1")."
";  
echo mysql_result($query , 1, "column1")."
";  
echo mysql_result($query , 2, "column1")."
";  
?>  

Note : 此函数功能少,但使用方便。  

4、mysql_fetch_object()  
格式: object mysql_fetch_object(int query)  

能对指定的字段进行循环读取,执行成功,将以对象object的形式返回数值,失败则返回False值。  

例子:  
$query = mysql_query($sql , $connect);  
while($object = mysql_fetch_object($query))  
{  
echo $object->column1 . "
";  
echo $object->column2 . "
";  
echo $object->column3 . "
";  
}  
?>  

Note : mysql_fetch_object()函数执行成功后返回的是1个对象object !  
操作如下:  
$object->字段名  

5、mysql_data_seek()  
格式:int mysql_data_seek(int row , int query);  
移动游标到指定的行(row_number)  
执行成功,返回真值,失败,返回False值。  
此函数可以与mysql_fetch_array()或mysql_fetch_row()配合使用,即在使用mysql_data_seek()函数之后,就可以用mysql_fetch_array()或mysql_fetch_row()函数来显示指定的行了。  

例子:  
$query = mysql_query($sql , $connect);  
$seek = mysql_data_seek($query , 2);  
$arrary = mysql_fetch_array($query);  
echo $array[column1]."
";  
echo $array[column2]."
";  
?>  

<6>.数据库级database的操作函数(2个):  

1、mysql_create_db()  
格式:int mysql_create_db(string database name , int link_identifier);  

通过程序来建立1个数据库database,当然你也可以用mysql_query()或者mysql_db_query()函数来建立或删除database  

但我们可以用这个函数更为方便地建立1个database。  
成功返回1个真值,失败,则返回1个false。  

例子:  

$connect = mysql_connect("$hostname","$user","$pwd");  
$create = mysql_create_db("dbtest" , $connect);  
if($create) echo "create database dbtest successed!";  
else echo "create database dbtest failed!";  

?>  

2、mysql_drop_db()  
格式:int mysql_drop_db(string database name , int link_identifier);  

通过程序来删除1个数据库database。  

但我们可以用这个函数更为方便地删除1个database。  
成功返回1个真值,失败,则返回1个false。  

例子:  

$connect = mysql_connect("$hostname","$user","$pwd");  
$create = mysql_drop_db("dbtest" , $connect);  
if($create) echo "drop database dbtest successed!";  
else echo "drop database dbtest failed!";  

?>  

Note : 如用mysql_query()或mysql_db_query(),则SQL语句应为:  
(1)create database dbtest  
(2)drop database dbtest 7) 数据库信息函数(2个):  

1、mysql_fetch_field()  
格式:object mysql_fetch_field(int query , int [field_offset]);  

返回1个对象,即一哈希表,下标有:  
table : 表名  
name : 字段名  
max_length : 该字段的最大长度  
not_null : 字段为not null则返回1,否则返回0  
primary_key : 字段为primary key则返回1,否则返回0  
unique_key : 字段为unique key则返回1,否则返回0  
multiple_key : 字段为非unique key则返回1,否则返回0  
numeric : 字段为numeric则返回1,否则返回0  
blob : 字段为blob则返回1,否则返回0  
type : 字段的类型  
unsigned : 字段为unsigned则返回1,否则返回0  
zerofill : 字段为zero filled则返回1,否则返回0  

引用格式为:对象名->下标名  

使用此函数可以得到表名、字段名、类型.......  

例子:  

$query = mysql_query($sql , $connect);  
while($object = mysql_fetch_field($query))  
{  
echo "table name : ".$object->table."
";  
echo "field name : ".$object->name."
";  
echo "primary key : ".$object->primary_key."
";  
echo "not null : ".$object->not_null."
";  
echo "field type : ".$object->type."
";  
echo "field max length : ".$object->max_length."
";  
}  
?>  

Note : 哈希表的是从0坐标开始的,即第一个字段为哈希表中的0项。  
如果我们想直接得到哈希表的第三项即第三个字段的信息,可用如下格式:  
$query = mysql_query($sql , $connect);  
$object = mysql_fetch_field($query , 2);  
echo "table name : ".$object->table."
";  
echo "field name : ".$object->name."
";  
echo "primary key : ".$object->primary_key."
";  
echo "not null : ".$object->not_null."
";  
echo "field type : ".$object->type."
";  
echo "field max length : ".$object->max_length."
";  
?>  

其实这也可以通过下面这个函数来达到同样的目的。  

2、mysql_field_seek()  
格式:int mysql_field_seek(int $query , int field_offset);  

将游标移到指定的字段上。  
例子:  

$query = mysql_query($sql , $connect);  
$seek = mysql_field_seek($query , 2);  
$object = mysql_fetch_field($query);  
echo "table name : ".$object->table."
";  
echo "field name : ".$object->name."
";  
echo "primary key : ".$object->primary_key."
";  
echo "not null : ".$object->not_null."
";  
echo "field type : ".$object->type."
";  
echo "field max length : ".$object->max_length."
";  
?>  

这样也达到与上例同样的要求。  

8) 取数据库名和表名(2个):  

1、mysql_list_dbs()  
格式: int mysql_list_dbs(int link_identifier);  
取得所有可用的数据库名(database name)。  

例子:  

$connect = mysql_connect($host , $usr ,$pwd);  
$dbs = mysql_list_dbs($connect);  
$rows = mysql_num_rows($dbs);  
echo "database total : ".$rows;  
$i = 0;  
while($i<$rows)  
{  
$db_name[$i] = mysql_tablename($dbs , $i);  
echo $db_name[$i];  
$i++;  
}  
?>  
即可依次显示出MySQL中所有的数据库名字(database name )。  
Note : 相当于MySQL中的 show databases命令  

2、mysql_list_tables()  
格式:int mysql_list_tables(string database name);  
显示该数据库下所有的表的名字Table name。  

例子:  

$connect = mysql_connect($host , $usr , $pwd);  
$tables = mysql_list_tables("mysql");  
$rows = mysql_num_rows($tables);  
echo "Table total : ".$rows;  
$i = 0;  
while($i<$rows)  
{  
$table_name[$i] = mysql_tablename($tables , $i);  
echo $table_name[$i];  
$i++;  
}  

?>  

即可依次显示出mysql下所有的表的名字  
Note : 相当于MySQL中的 show tables命令(先要用 use mysql命令选中1个数据库)  
(出处:风闪)

PHP 相关文章推荐
解析php中array_merge与array+array的区别
Jun 21 PHP
PHP系统命令函数使用分析
Jul 05 PHP
php判断ip黑名单程序代码实例
Feb 24 PHP
ThinkPHP中url隐藏入口文件后接收alipay传值的方法
Dec 09 PHP
php实现过滤字符串中的中文和数字实例
Jul 29 PHP
全面解析PHP操作Memcache基本函数
Jul 14 PHP
PHP多进程编程之僵尸进程问题的理解
Oct 15 PHP
Laravel实现短信注册的示例代码
May 29 PHP
php版本CKEditor 4和CKFinder安装及配置方法图文教程
Jun 05 PHP
Laravel 中使用简单的方法跟踪用户是否在线(推荐)
Oct 30 PHP
PHP 实现缩略图
Mar 09 PHP
PHP中strval()函数实例用法
Jun 07 PHP
开发大型PHP项目的方法
Oct 09 #PHP
怎么使 Mysql 数据同步
Oct 09 #PHP
PHP 中的类
Oct 09 #PHP
用PHP实现验证码功能
Oct 09 #PHP
汉字转化为拼音(php版)
Oct 09 #PHP
如何限制访问者的ip(PHPBB的代码)
Oct 09 #PHP
substr()函数中文版
Oct 09 #PHP
You might like
附件名前加网站名
2008/03/23 PHP
PHP实现将textarea的值根据回车换行拆分至数组
2015/06/10 PHP
[原创]php求圆周率的简单实现方法
2016/05/30 PHP
PHP编写daemon process详解及实例代码
2016/09/30 PHP
浅谈PHP中new self()和new static()的区别
2017/08/11 PHP
php面向对象程序设计入门教程
2019/06/22 PHP
TNC vs IO BO3 第一场2.13
2021/03/10 DOTA
xml 与javascript结合的问题解决方法
2007/03/24 Javascript
关于文本限制字数的js代码
2007/04/02 Javascript
JS判断当前日期是否大于某个日期的实现代码
2012/09/02 Javascript
seajs1.3.0源码解析之module依赖有序加载
2012/11/07 Javascript
js简单的表格添加行和删除行操作示例
2014/03/31 Javascript
JavaScript获得url查询参数的方法
2015/07/02 Javascript
JavaScript保留关键字汇总
2015/12/01 Javascript
js+canvas绘制矩形的方法
2016/01/28 Javascript
基于JavaScript实现轮播图代码
2016/07/14 Javascript
利用Angular.js限制textarea输入的字数
2016/10/20 Javascript
Vue.js原理分析之observer模块详解
2017/02/17 Javascript
jquery实现放大镜简洁代码(推荐)
2017/06/08 jQuery
使用百度地图实现地图网格的示例
2018/02/06 Javascript
nodejs微信扫码支付功能实现
2018/02/17 NodeJs
基于JS实现快速读取TXT文件
2020/08/25 Javascript
python如何对实例属性进行类型检查
2018/03/20 Python
Python实现E-Mail收集插件实例教程
2019/02/06 Python
tornado+celery的简单使用详解
2019/12/21 Python
Python3.6 中的pyinstaller安装和使用教程
2020/03/16 Python
Django crontab定时任务模块操作方法解析
2020/09/10 Python
如何利用python 读取配置文件
2021/01/06 Python
详解前端HTML5几种存储方式的总结
2016/12/27 HTML / CSS
美国新兴城市生活方式零售商:VILLA
2017/12/06 全球购物
Lookfantastic葡萄牙官方网站:欧洲第一大化妆品零售商
2018/03/17 全球购物
Fox Racing英国官网:越野摩托车和山地自行车服装
2020/02/26 全球购物
成品库仓管员岗位职责
2014/04/06 职场文书
合伙协议书范本
2014/04/21 职场文书
幼儿园教师教育随笔
2015/08/14 职场文书
大学生社区义工服务心得体会
2016/01/22 职场文书