常用的php ADODB使用方法集锦


Posted in PHP onMarch 25, 2008
<?php        //定义数据库变量         
$DB_TYPE     = "mysql";         
$DB_HOST     = "localhost";         
$DB_USER     = "root";         
$DB_PASS     = "";         
$DB_DATABASE = "ai-part";         
require_once("../adodb/adodb.inc.php");         
$db = NewADOConnection("$DB_TYPE");//建立数据库对象         
$db->debug = true;//数据库的DEBUG测试,默认值是false         
$ADODB_FETCH_MODE = ADODB_FETCH_ASSOC;//返回的记录集形式,关联形式         
/***       
返回的记录集形式       
define('ADODB_FETCH_DEFAULT',0);       
define('ADODB_FETCH_NUM',1);       
define('ADODB_FETCH_ASSOC',2);       
define('ADODB_FETCH_BOTH',3);        
以上常量,在adodb.inc.php里定义了,也就是可用"$ADODB_FETCH_MODE=2"方式       
ADODB_FETCH_NUM   返回的记录集中的索引,是数字形式,即数据库字段的排序顺序值       
ADODB_FETCH_ASSOC 返回的记录集中的索引,是原数据库字段名       
ADODB_FETCH_BOTH 和 ADODB_FETCH_DEFAULT 是同时返回以上两种。某些数据库不支持       
An example:        
    $ADODB_FETCH_MODE = ADODB_FETCH_NUM;        
    $rs1 = $db->Execute('select * from table');        
    $ADODB_FETCH_MODE = ADODB_FETCH_ASSOC;        
    $rs2 = $db->Execute('select * from table');        
    print_r($rs1->fields); # 返回的数组是: array([0]=>'v0',[1] =>'v1')        
    print_r($rs2->fields); # 返回的数组是: array(['col1']=>'v0',['col2'] =>'v1')        
***/        
//连接数据库,方法有Connect,PConnect,NConnect,一般使用Connect         
if (!@$db->Connect("$DB_HOST", "$DB_USER", "$DB_PASS", "$DB_DATABASE")) {         
    exit('<a href="/">服务器忙,请稍候再访问</a>');         
}         
/*       
$db->  $rs-> 此类的使用方法       
Execute($sql),执行参数中的$sql语句       
SelectLimit($sql,$numrows=-1,$offset=-1) $numrows:取几条记录,$offset,从第几条开始取,一般是用于分页,或只取出几条记录的时候用       
*/        
//Example: 取出多个记录         
$sql = "Select * FROM table orDER BY id DESC";         
if (!$rs = $db->Execute($sql)) {//执行SQL语句,并把结果返回给$rs变量         
    echo $db->ErrorMsg();//这个是打印出错信息         
    $db->Close();//关闭数据库         
    exit();         
}         
while (!$rs->EOF) {//遍历记录集         
    echo $rs->fields['username'] . '<br>';         
      //print_r($rs->fields)试试,$rs->fields['字段名'],返回的是这个字段里的值         
    $rs->MoveNext();//将指针指到下一条记录,否则出现死循环!         
}         
$rs->Close();//关闭以便释放内存         
//插入新记录         
$sql = "Insert table (user_type,username) VALUES (3, 'liucheng')";         
$db->Execute($sql);         
//更新记录         
$sql = "Update table SET user_type=3 Where id=2";         
$db->Execute($sql);         
//删除记录         
$sql = "Delete FROM table Where id=2";         
$db->Execute($sql);         
// 取单个记录         
//$db->GetRow($sql), 取第一条记录,并返回一个数组,出错返回false         
$sql = "Select username,password,user_type FROM table Where id=3";         
$data_ary = $db->GetRow($sql);         
if ($data_ary == false) {         
    echo '没有找到此记录';         
    exit();         
} else {         
    echo $data_ary['username'] . ' ' . $data_ary['password'] . ' ' . $data_ary['user_type'] . '<br>';         
}         
//另一种方法         
$sql = "Select username,password,user_type FROM table Where id=3";         
if (!$rs = $db->Execute($sql)) {         
    echo $db->ErrorMsg();         
    $db->Close();         
    exit();         
}         
if (!$result = $rs->FetchRow()) {         
    echo '没有找到此记录';         
    exit();         
} else {         
    echo $result['username'] . ' ' . $result['password'] . ' ' . $result['user_type'] . '<br>';         
}         
// 取单个字段         
//$db->GetOne($sql) 取出第一条记录的第一个字段的值,出错则返回false         
$sql = "Select COUNT(id) FROM table";         
$record_nums = $db->GetOne($sql);         
echo $record_nums;         
$sql = "Select username,password,user_type FROM table Where user_id=1";         
$result = $db->GetOne($sql);         
echo $result;//打印出username的值         
/*       
在进行添加,修改,删除记录操作时,       
要对字符串型的字段,使用$db->qstr()对用户输入的字符进行处理,       
对数字型字段,要进行数据判断       
更新记录,注意:这是针对php.ini中,magic_quotes被设置为Off的情况,如果不确定,可以使用       
$db->qstr($content,get_magic_quotes_gpc())       
注意:content= 等号右边,没有单引号       
*/        
$sql = "Update table SET content=" . $db->qstr($content) . " Where id=2";         
$db->Execute($sql);         
        
/*$db->Insert_ID(),无参数,返回刚刚插入的那条记录的ID值,仅支持部分数据库,带auto-increment功能的数据库,如PostgreSQL, MySQL 和 MS SQL        
*/        
//Example:         
$sql = "Insert table (user_type,username) VALUES (3, 'liucheng')";         
$db->Execute($sql);         
$data_id = $db->Insert_ID();         
echo $data_id;         
/*$db->GenID($seqName = 'adodbseq',$startID=1),产生一个ID值.$seqName:用于产生此ID的数据库表名,$startID:起始值,一般不用设置,它会把$seqName中的值自动加1.支持部分数据库,某些数据库不支持       
Insert_ID,GenID,一般我用GenID,使用它的目的,是在插入记录后,要马上得到它的ID时,才用       
*/        
/*Example:       
先创建一个列名为user_id_seq的表,里面只有一个字段,id,int(10),NOT NULL,然后插入一条值为0的记录       
*/        
$user_id = $db->GenID('user_id_seq');         
$sql = "Insert table (id, user_type,username) VALUES (" . $user_id . ", 3, 'liucheng')";         
$db->Execute($sql);         
/*       
$rs->RecordCount(),取出记录集总数,无参数       
它好像是把取出的记录集,用count()数组的方法,取得数据的数量       
如果取大量数据,效率比较慢,建议使用SQL里的COUNT(*)的方法       
$sql = "Select COUNT(*) FROM table", 用此方法时,不要在SQL里加ORDER BY,那样会降低执行速度       
Example:       
*/        
$sql = "Select * FROM table orDER BY id DESC";         
if (!$rs = $db->Execute($sql)) {         
    echo $db->ErrorMsg();         
    $db->Close();         
    exit();         
}         
$record_nums = $rs->RecordCount();         
/*       
如果想对某一结果集,要进行两次同样的循环处理,可以用下面方法       
以下,只是一个例子,只为说明$rs->MoveFirst()的使用方法       
*/        
$sql = "Select * FROM table orDER BY id DESC";         
if (!$rs = $db->Execute($sql)) {         
    echo $db->ErrorMsg();         
    $db->Close();         
    exit();         
}         
$username_ary = array();         
while (!$rs->EOF) {         
    $username_ary[] = $rs->fields['username']         
    echo $rs->fields['username'] . '<br>';//print_r($rs->fields)试试,$rs->fields['字段名'],返回的是这个字段里的值         
    $rs->MoveNext();//将指针指到下一条记录,不用的话,会出现死循环!         
}         
$username_ary = array_unique($username_ary);         
$rs->MoveFirst();//将指针指回第一条记录         
while (!$rs->EOF) {         
    echo $rs->fields['password'] . '<br>';//print_r($rs->fields)试试,$rs->fields['字段名'],返回的是这个字段里的值         
    $rs->MoveNext();//将指针指到下一条记录         
}         
$rs->Close();         
//当本页程序,对数据库的操作完毕后,要$db->Close();         
$db->Close();         
/*一个不错的方法 */        
if (isset($db)) {         
    $db->Close();         
}         
?> 
PHP 相关文章推荐
PHP与已存在的Java应用程序集成
Oct 09 PHP
模仿OSO的论坛(四)
Oct 09 PHP
php cookis创建实现代码
Mar 16 PHP
PHP仿盗链代码
Jun 03 PHP
destoon公司主页模板风格的添加方法
Jun 20 PHP
PHP调用MySQL存储过程并返回值的方法
Dec 26 PHP
ThinkPHP中数据操作案例分析
Sep 27 PHP
Symfony2学习笔记之系统路由详解
Mar 17 PHP
Zend Framework教程之Zend_Db_Table表关联实例详解
Mar 23 PHP
Yii2使用dropdownlist实现地区三级联动功能的方法
Jul 18 PHP
thinkPHP5框架auth权限控制类与用法示例
Jun 12 PHP
php变量与字符串的增删改查操作示例
May 07 PHP
PHP中ADODB类详解
Mar 25 #PHP
php下判断数组中是否存在相同的值array_unique
Mar 25 #PHP
php获取mysql版本的几种方法小结
Mar 25 #PHP
非常不错的MySQL优化的8条经验
Mar 24 #PHP
php不用正则采集速度探究总结
Mar 24 #PHP
php木马攻击防御之道
Mar 24 #PHP
php入门小知识
Mar 24 #PHP
You might like
php使用array_rand()函数从数组中随机选择一个或多个元素
2014/04/28 PHP
PHPExcel实现表格导出功能示例【带有多个工作sheet】
2018/06/13 PHP
input 高级限制级用法
2009/03/26 Javascript
关于juqery radio写法的兼容性问题(新老版本jquery)
2010/06/14 Javascript
扩展Jquery插件处理mouseover时内部有子元素时发生样式闪烁
2011/12/08 Javascript
Flexigrid在IE下不显示数据的处理的解决方法
2013/10/24 Javascript
jQuery获取Radio,CheckBox选择的Value值(示例代码)
2013/12/12 Javascript
JavaScript页面模板库handlebars的简单用法
2015/03/02 Javascript
什么是Vue.js框架 为什么选择它?
2017/10/17 Javascript
JS处理一些简单计算题
2018/02/24 Javascript
详解mpvue开发小程序小总结
2018/07/25 Javascript
JavaScript设计模式之享元模式实例详解
2019/01/17 Javascript
详解微信小程序缓存--缓存时效性
2019/05/02 Javascript
[05:06]DOTA2-DPC中国联赛 正赛 VG vs Magma选手采访
2021/03/11 DOTA
python判断windows隐藏文件的方法
2014/03/21 Python
在Python中使用CasperJS获取JS渲染生成的HTML内容的教程
2015/04/09 Python
Python中几种导入模块的方式总结
2017/04/27 Python
python使用os.listdir和os.walk获得文件的路径的方法
2017/12/16 Python
python爬虫获取多页天涯帖子
2018/02/23 Python
python 串口读取+存储+输出处理实例
2019/12/26 Python
详解python 破解网站反爬虫的两种简单方法
2020/02/09 Python
css3编写浏览器背景渐变背景色的方法
2018/03/05 HTML / CSS
瑞典领先的汽车零部件网上零售商:bildelaronline24.se
2017/01/12 全球购物
JD Sports芬兰:英国领先的运动鞋和运动服饰零售商
2018/11/16 全球购物
Otticanet意大利:最顶尖的世界名牌眼镜, 能得到打折季的价格
2019/03/10 全球购物
介绍下WebSphere的安全性
2013/01/31 面试题
《小池塘》教学反思
2014/02/28 职场文书
我的中国梦演讲稿300字
2014/08/19 职场文书
做一个有道德的人活动实施方案
2014/08/23 职场文书
资源环境与城乡规划管理专业自荐书
2014/09/26 职场文书
2014年办公室文员工作总结
2014/11/12 职场文书
会计师事务所实习证明
2014/11/16 职场文书
绵山导游词
2015/02/05 职场文书
2015年全民国防教育日活动总结
2015/03/23 职场文书
推荐六本经典文学奖书籍:此生必读
2019/08/22 职场文书
一文教你快速生成MySQL数据库关系图
2022/06/28 Redis