小李SEO博客

网站优化服务

织梦cms数据库类常用函数说明

昨天整理了一下自己在使用织梦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相关函数进行数据库操作,在非不得已情况,项目中一般不使用这个变量。


上一篇:织梦cms自带邮件功能实现自定义表单邮件通知 下一篇:织梦cms相关文章中实现orderby参数排列的方法
织梦cms相关文章阅读
  • 织梦cms本地上传图片缩略图加水印方法

    小李网络公司介绍织梦cms本地上传图片缩略图加水印方法知识,包括上传图片显示缺少源文件地址dedecms上传缩略图dedecms图片缩略图织梦上传织梦https图片格式织梦https之后上传不了图片织梦会员...

  • 织梦cms5.7后台登陆密码忘记修改方法

    小李网络公司介绍织梦cms5.7后台登陆密码忘记修改方法知识,包括dedecms后台管理系统账号密码忘记了怎么办 - 百度经验,教程:忘记最新dedecms5.7后台管理员密码,织梦cms忘记后台登录密码的三种解决...

  • 织梦cms让{dede:list}标签支持weight权重排序教程

    小李网络公司介绍织梦cms让{dede:list}标签支持weight权重排序教程知识,包括dedelist条件语句dede标签的使用dede阅读数标签weightlistdedelist权重排列dedeif调用dede织梦调用标签dedelist和arclistdede排序方式...

  • 织梦cms网站验证码代码实现方法

    小李网络公司介绍织梦cms网站验证码代码实现方法知识,包括dedecms装代码dedecms改网站代码dedecms分离代码dedecms文章代码dedecms代码模板dedecms嵌套代码dedecms批量代码dedecms短信注册....

  • 织梦cms栏目绑定二级域名RSS文件地址URL错误

    小李网络公司介绍织梦cms栏目绑定二级域名RSS文件地址URL错误知识,包括解决Dedecms生成RSS地图地址出错全都多了一个网址的问题,常用的二级域名一个意外错误使您无法复制该文件二级域名怎么看...

  • 织梦cmsv5.7tags标签按ID排序解决办法

    小李网络公司介绍织梦cmsv5.7tags标签按ID排序解决办法知识,包括网站的tag标签是什么tags标签列表如何将数据透视图的自由排序数据透视图行标签水平排列tags意思dedecmstag标签插件高效标签....

  • 织梦cms网站TAG标签显示单个标签共有多少篇文章的方法

    小李网络公司介绍织梦cms网站TAG标签显示单个标签共有多少篇文章知识,包括织梦cms建站教程织梦 建站dedecms织梦系统织梦列表页标签织梦超级标签织梦友情链接标签织梦标签理解织梦随机标签织...

  • 织梦cms列表页标签使用方法

    小李网络公司介绍织梦cms列表页标签使用方法知识,包括Dedecms列表页标签list/pagelist使用方法及pagelist的样式,list标签使用dededatalist标签vue遍历listdedecms标签分类dedecmslist循环iddedecms标签判断list层层...

  • 织梦cms采集规则过滤与替换

    小李网络公司介绍织梦cms采集规则过滤与替换知识,包括dede织梦_采集规则技巧-过滤-替换_黑鹰-CSDN博客,代入规则和替换规则excel怎么设置规则常识替换....

  • 织梦cms自动关键字内链生成解决方法

    小李网络公司介绍织梦cms自动关键字内链生成知识,包括DedeCms5.5全站自动给关键字加内链的修改方法_织梦58.关键字有哪些发内链怎么发怎么添加内链网站内链布局内链和外链网站内链内链的结构...

  • 织梦cms调用外部栏目新窗口target="_blank"

    小李网络公司介绍织梦cms调用外部栏目新窗口target="_blank"知识.包括target_blank什么意思target标签怎么用targetblank—blankblank标签a连接的targetblank space的歌词a target属性blank space的歌词中文blank中文...

  • 织梦cms采集出现Character解决方法

    小李网络公司介绍织梦cms采集出现Character解决方法知识,包括dedecms采集出现Character postion **,‘field’Error解决方法,dedecms实时采集织梦采集教程采集dedecms织梦自动采集发布dedecms采集模块_dedecms字段...

SEO公司排名
 
QQ在线咨询
SEM竞价推广
137-1296-7640
SEO优化外包
137-1296-7640