DedeCMS数据库类常用函数说明_

作者 : 叶 落风前 本文共1852个字,预计阅读时间需要5分钟 发布时间: 2020-05-30 共56人阅读

昨天整理了一下自己在使用织梦DedeCMS时常用到的一些数据库类函数,大致有以下几种:

首先说一下数据库类文件位置:/include/dedesql.class.php(mysql)或/include/dedesqli.class.php(mysqli)

系统会自动载入 dedesql.class.php文件,并用$dsql = $db = new DedeSql(FALSE);初始化数据库连接,因此我们不需要再单独初始化这个类,可以直接用$dsql或$db进行操作。

DEDECMS提示:为了防止错误,操作完后不必关闭数据库。

数据库类中常用到的方法

1.获取错误描述:

 

$error = $dsql->GetError();

返回值为错误描述信息

2.执行一个不返回结果的SQL语句,如update,delete,insert等

 

$result = $dsql->ExecuteNoneQuery($sql);

返回值为SQL语句是否执行成功(TRUE/FALSE)

该方法可以用ExecNoneQuery()替代,它实际上执行的也是ExecuteNoneQuery()

3.执行一个返回影响记录条数的SQL语句,如update,delete,insert等

 

$result = $dsql->ExecuteNoneQuery2($sql);

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

4.执行一个SQL语句,返回前一条记录或仅返回一条记录

 

$result = $dsql->GetOne($sql);

即使你的SQL语句中没有写Limit,系统也会自动为其加上limit 0,1。

下面是GetOne()中为其加上limit的语句:

 

if(!preg_match("/LIMIT/i",$sql)) $this->SetQuery(preg_replace("/[,;]$/i", '', trim($sql))." LIMIT 0,1;");

5.执行条件查询(select)语句

 

$dsql->SetQuery($sql);

$dsql->Execute();

while($arr = $dsql->GetArray()){

    //这里对查询结果进行操作

}

上面的写法可以简化为:

 

$dsql->Execute("me",$sql);

while($arr = $dsql->GetArray()){

    //这里对查询结果进行操作

}

GetArray()的定义(Line:383)

 

function GetArray($rsid="me",$acctype=MYSQL_ASSOC);

其中”me”($rsid)被称为记录集游标,用来区分不同的查询,当$rsid为”me”的时候,GetArray()的参数可以省略,否则必须给出参数$rsid。如:

 

$dsql->Execute("q1",$sql1);

while($arr = $dsql->GetArray("q1")){

    $dsql->Execute("q2",$dsql2);

    while($arr2 = $dsql->GetArray("q2")){

        //这里对查询结果进行操作

    }

}

6.检查某数据表是否存在

 

$result = $dsql->IsTable($tbname);

返回值为布尔值

7.获取MySql的版本号

 

$version = $dsql->GetVersion($isformat=TRUE)

返回值为双精度浮点数

8.获取查询的总记录数

 

$num = $dsql->GetTotalRow($rsid="me");

9.获取上一步INSERT操作产生的ID

 

$id = $dsql->GetLastID();

10.释放记录集占用的资源

 

$dsql->FreeResult($rsid="me");//(释放游标为"me"的记录集资源)

$dsql->FreeResultAll();//(释放所有记录集资源)

11.设置SQL语句,会自动把SQL语句里的dede_替换为$this->dbPrefix(在配置文件中为$cfg_dbprefix)

 

$dsql->SetQuery($sql);

$dsql->SetSql($sql);//(功能一样)

12.重新选择要操作的数据库

 

$dsql->SelectDB($dbname);

13.获取数据库连接标识

 

$dsql->linkID;

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

完整源码网ym0.cc,专业提供制网站源码,网站模板,源码下载,商业源码,游戏源码,找源码就到完整源码网 免责声明:本站所提供的资源来自于网络,版权争议与本站无关,版权归原创者所有! 仅限用于学习和研究目的,不得将上述内容资源用于商业或者非法用途. 否则,一切后果请用户自负。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容资源。如果上述内容资对您的版权或者利益造成损害,请提供相应的资质证明,我们将于3个工作日内予以删除。 本站不保证所提供下载的资源的准确性、安全性和完整性,源码仅供下载学习之用! 如用于商业或者非法用途,与本站无关,一切后果请用户自负! 本站也不承担用户因使用这些下载资源对自己和他人造成任何形式的损失或伤害。 如有侵权、不妥之处,请联系站长以便删除。 敬请谅解!侵权/投稿邮箱:157529987@qq.com!
完整源码网-ym0.cc » DedeCMS数据库类常用函数说明_

常见问题FAQ

开通VIP的好处?
VIP会员根据等级在相应的有效期内享有本站所有资源免费下载资源的权力,免费查看隐藏内容的权力,免费查看视频的权力,同时本站商品还会获得打折价格,并且拥有其他特殊的权力。
完整源码支持最新版本吗?
完整源码网支持永久更新!

发表评论