dedeCMS数据库类的一些常见的使用方法

转载自:http://help.dedecms.com/v53/archives/functions/db/

 

 一、知识点

系统会自动载入 dedesql.class.php 文件,并用

$dsql = $db = new DedeSql(false);

进行初始化数据库连接,因此在工程所有文件中均不需要单独初始化这个类,可直接用 $dsql 或 $db 进行操作,为了防止错误,操作完后不必关闭数据库。

eg:

<?php 
 
require_once(dirname(__FILE__)."/include/config_base.php"); 
$dsql = new DedeSql(false); 
$dsql->ExecuteNoneQuery("Update `mbtx_admin` 
set pwd='e10adc3949ba59abbe56e057' where userid='admin'"); 
$dsql->Close(); 
echo '密码重置成功!新密码为123456。'; 
?> 


二、常用的方法

1、执行一个非查询类型的SQL语句,如 insert 、create 、update 等

$rs = $db->ExecuteNoneQuery($sql);


返回值为是否执行成功

2、执行一个非查询类型的SQL语句,并返回成功记录数

$rs = $db->ExecuteNoneQuery2($sql);

 

与上面相比,它返回的是影响的记录数,而不是布尔值

3、返回单个记录

$arr = $db->GetOne($sql);


$dsql 如果不带 limit ,系统会自动加上 limit 0,1

4、执行条件查询语句

$db->SetQuery($dsql);
$db->Execute();
while($arr = $db->GetArray())
{
}


可以简化为:

$db->Execute('me',$dsql);
while($arr = $db->GetArray())
{
}


'me' 为记录集游标,用于区分不同的查询,如:

$db->Execute('me',$dsql);
while($arr = $db->GetArray())
{
   $db->Execute('2',$dsql2);
   while($arr2 = $db->GetArray())
   {
      
   }
}



像这种情况必须指定一个值区分默认的'me'参数,否则会出错

$db->GetArray($rsid,$acctype) 参数
$rsid="me"
$acctype=MYSQL_ASSOC


在查询游标中读取数据还可以用

$db->GetObject($rsid="me");


返回的结果是用类结构表示的值

5、获取上一个插入的自动递增主键id值

$db->GetLastID();


6、获得查询的总记录数

$db->GetTotalRow($rsid="me")


7、获得MySql的版本号

$db->GetVersion($isformat=true)


默认的情况下会转换成 x.xx 形式浮点数

8、析放某查询的资源

$db->FreeResult($rsid="me");


9、在数据库中是否存在某数据表

$db->IsTable($tbname)

10、重新选择要操作的数据库

$db->SelectDB($dbname);


11、获得数据库连接标识

$db->linkID

获得这个连接标识后,可以直接用mysql相关函数进行数据库操作,在非不得已的情况,项目中一般不使用这个变量



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值