您现在的位置是:首页 > 教程 > dedecms教程dedecms教程
dedecms数据库类常用函数归类详细说明
静曼2023-09-26 19:37:35dedecms教程已有人查阅
导读昨天整理了一下自己在使用DedeCMS时常用到的一些数据库类函数,大致有以下几种:首先说一下数据库类文件位置:/include/dedesql.class.php(mysql)或/include/dedesqli.class.php(mysqli)
昨天整理了一下自己在使用DedeCMS时常用到的一些数据库类函数,大致有以下几种:
首先说一下数据库类文件位置:/include/dedesql.class.php(mysql)或/include/dedesqli.class.php(mysqli)
系统会自动载入 dedesql.class.php文件,并用
DEDECMS提示:为了防止错误,操作完后不必关闭数据库。
数据库类中常用到的方法
1.获取错误描述:
2.执行一个不返回结果的SQL语句,如update,delete,insert等
该方法可以用ExecNoneQuery()替代,它实际上执行的也是ExecuteNoneQuery()
3.执行一个返回影响记录条数的SQL语句,如update,delete,insert等
4.执行一个SQL语句,返回前一条记录或仅返回一条记录
$result = $dsql->GetOne($sql);
即使你的SQL语句中没有写Limit,系统也会自动为其加上limit 0,1。
下面是GetOne()中为其加上limit的语句:
7.获取MySql的版本号
8.获取查询的总记录数
首先说一下数据库类文件位置:/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相关函数进行数据库操作,在非不得已情况,项目中一般不使用这个变量。
本文标签:
很赞哦! ()
相关文章
- dedecms织梦错误(PHP 5.3 and above) Please set 'request_order'
- dedecms文章列表页添加缩略图的实现方法
- dedecms织梦如何调用Discuz论坛主题等数据
- dedecms织梦限制栏目列表生成的最大页数的方法
- 织梦dedecms添加RSS订阅功能的代码实例
- dedecms织梦在首页或列表页调用整篇文章内容的方法
- 织梦dedecms系统的安装方法步骤教程
- 织梦dedecms给栏目加一个英文栏目名字段的实现方法
- dedecms织梦验证码的代码注释介绍
- 织梦dedecms如何让文章列表实现隔行换色的代码实例
- dedecms织梦tag彩色关键字彩色标签修改方法
- dedecms织梦网页调用指定栏目信息的实现方法
随机图文
-
dedecms去除列表页文章标题加粗标签代码实例
生成的列表模板中,列表文章标题全都加粗加黑了,这样看的特别扭。最近在用DEDECMS搭架网站的时候,我碰到这种情况:就是生成的列表模板中 -
dedecms织梦自定义php文件支持include标签
dedecms织梦问答等模块支持arclist标签,实现随机调用其他栏目文章就是让模块模板文件支持调用主站的模板,因为调用主站下的/templets/default/模板 -
dedecms5.7模板标签调用方法总结
1.关键描述调用标签:2.模板路径调用标签:3.网站标题调用标签:4.栏目导航调用标签:5.指定调用栏目标签:6.频道栏目调用标签: -
织梦系统配置为空怎么办
今天在网上搜索有关织梦模板教程的文章,发现一个和系统配置参数的文章,感觉很有用处,故转载过来,供大家参考。
留言与评论 (共有 条评论) |