Dedesql数据库类详解(二次开发必备教程)(转)

http://www.dedecms.com/help/development/2009/1028/1076.html

织梦DedeCMS的二次开发不仅仅是会写写织梦的标签,会制作织梦的模板。很多时候,我们需要对织梦DedeCMS的数据库进行查询、插入、删除等等之类的操作,进行这一类的操作之前,我们必须知道织梦DedeCMS的数据库类,No牛网整理了织梦天涯版主关于DedeCMS程序的dedesql类常见的用法讲解的文章,希望有朋友用的上。

1.创建数据表

为了让讲解更加的贴合实际,天涯版主创建了一个名为"dede_test"的表,里面就2个字段,1个id,作为唯一标识,另一个name作为名称。然后往里面添加测试数据,这个操作类似于Access或者EXCEL,比较简单,这里不做冗述。

 

使用如下的SQL语句插入一些数据供操作使用:

1
INSERT INTO `dede_test` VALUES ('1', '测试名字1');INSERT INTO `dede_test` VALUES ('2', '这是第二个');INSERT INTO `dede_test` VALUES ('3', '第三个喽');INSERT INTO `dede_test` VALUES ('4', '第四个');

2.连接数据库

在对织梦DedeCMS的数据库进行操作之前,当然是先连接数据库了,方法非常简单。只需要在操作的文件中引入include文件夹下面的common.inc.php文件即可。可以在网站根目录中创建一个test.php的文件来进行相关的测试操作,在这个文件中写入如下的代码:

1
<!--?php        require_once (dirname(__FILE__) . "/include/common.inc.php");        print_r($dsql);?-->

在浏览器中运行之后,查看源代码就可以得到如下图所示的代码:

织梦数据库操作结果1

这个就说明我们已经成功连接数据库了,[dbHost],[dbUser]...这些都是数据库的相关信息,也就是我们保存在配置文件中的\data\common.inc.php内容,引入数据库类的时候,默认就被创建了$dsql或者$db,所以直接引入配置文件就可以了。

接下来做一个简单的查询操作,接着上面的代码我们继续写test.php文件,代码如下:

1
<!--?php      require_once (dirname(__FILE__) . "/include/common.inc.php");      if($dsql--->IsTable('dede_test')){          //如果存在dede_test表          //-------------------          //|    查询一条记录 |          //|    GetOne()     |          //-------------------          //        ↓          $row = $dsql->GetOne("SELECT * FROM dede_test WHERE id = 3");          print_r($row);      }?>

这里我们用了$dsql类的2个方法,IsTable()以及GetOne(),IsTable先来判断这个表是否存在,如果存在我们就继续执行,他返回的是一个bool值,如果存在为true否则就为false。

接下来判断如果有这个表存在,则我们就执行查询单条记录的这个过程,即GetOne,通过帮助文档可以知道:$arr = $db->GetOne($sql);也就是说查询的sql语句会传送回来一个数组,我们运行test.php看到如下运行结果:

1
Array(    [id] => 3    [name] => 第三个喽)

这个说明我们查询dede_test这个表id为3的数据成功了,返回了一个$row数组,其中就存放了字段的值。当然我们可以用echo $row['name'];或者$row['id']来输出我们查询出来的结果。

3.查询数据库

刚才讲了查询一条记录,其实这个查询一条记录可以理解为我们内容页查询一篇文章,只是获取单条记录并将内容显示出来,但往往我们经常遇到的是查询列表,及{dede:arclist/}或者{dede:list/},查询列表的话涉及到查询多条记录。

继续修改test.php代码:

1
<!--?php      require_once (dirname(__FILE__) . "/include/common.inc.php");      if($dsql--->IsTable('dede_test')){          //如果存在dede_test表          //-------------------          //|    查询一条记录 |          //|    GetOne()     |          //-------------------          //        ↓          $row = $dsql->GetOne("SELECT * FROM dede_test WHERE id = 3");          echo "查询id=3的记录:<br>显示结果:";          print_r($row);          //-------------------          //|    查询多条记录 |          //|    Execute()     |          //-------------------          //        ↓          echo "<hr>查询dede_test表中的所有记录:<br>显示结果:<br>";          $sql = "SELECT * FROM dede_test";            $dsql->Execute('me',$sql);            while($arr = $dsql->GetArray('me'))            {                echo "id = {$arr['id']} ,name = {$arr['name']}<br>";            }      }?>

运行test.php看到显示以下的内容:

1
查询dede_test表中的所有记录:显示结果:id = 1 ,name = 测试名字1id = 2 ,name = 这是第二个id = 3 ,name = 第三个喽id = 4 ,name = 第四个

这个说明我们已经成功将表dede_test中的数据输出,当然主要是执行了那个"SELECT * FROM dede_test",这是一个最简单的sql查询语句,当然也能够用到order by这些排序或者条件去查询,详细可以参考sql相关内容。

同时这里需要说明的是这里除了用$dsql->GetArray('me')来获取内容到数组,还可以用$dsql->GetObject("me")获取内容到对象,不过调用方法有些不同,主要这里通过$dbobj->fieldname来调用查询出来的数据:

1
while($dbobj = $dsql->GetObject('me'))            {                echo "id = {$dbobj->id} ,name = {$dbobj->name}<br>";            }

4.插入删除操作数据库

上面我们介绍了如何用dsql来查询数据,主要有获取单条记录和获取多条记录2种,接下来我们来了解下使用dsql其他特性来为我们的test.php加入添加内容和删除内容的功能。先来了解下插入数据库的操作,我们先做一个表单,这个表单用于提交数据name的。表单代码如下:

1
<hr>用于提交数据的表单:<br><form action="test.php" type="post">    <input name="dopost" type="hidden" value="save">    名称:<input name="name" type="text" value="">    <input name="提交" type="submit" value="提交"></form>

这里我们用了一个隐藏域dopost来存放操作方法,输入框name用来存放输入数据,然后传递给当前页面,再进行处理,这时候我们需要在test.php中加入部分的表单处理操作:

1
//-------------------        //|    表单处理过程 |        //|    Save()     |        //-------------------        //        ↓      empty($dopost)? "" : $dopost;      if($dopost == "save"){          //如果执行插入操作          $sql = "INSERT INTO `dede_test` (`name`) VALUES ('{$name}')";          $dsql->ExecuteNoneQuery($sql); //执行这个插入语句          $lastInsertID = $dsql->GetLastID(); //获取插入后的最后的ID,然后再传给下一个页面          ShowMsg("成功增加一条记录内容!","test.php?id={$lastInsertID}");          exit();      }

这里主要是一个INSERT INTO 语句,然后通过$dsql的ExecuteNoneQuery方法来执行这个操作,并且获取插入数据最后一个id再将其传递给下一个页面以便高亮显示。我们可以在编辑框中插入一条数据来测试下,看看插入数据后的返回结果:

织梦数据库操作结果2

其实删除的操作也是如此,我们只需要稍微做个修改就可以了,增加一个dopost操作为del的判断,然后在显示数据后面增加一个超链接,将id以get方式进行传递.并最后进行处理。下面是我们修改循环查询输出的部分内容,有如下修改:

1
while($dbobj = $dsql->GetObject('me'))            {                if($id==$dbobj->id){                  //如果传递的id值和查询值相同,则高亮显示最后一条插入记录                    echo "<font color="red">id = {$dbobj->id} ,name = {$dbobj->name}</font> <a href="test.php?dopost=del&id={$dbobj->id}">[删除]</a>    <br>";//这里增加了一个删除的超链接                }else{                    echo "id = {$dbobj->id} ,name = {$dbobj->name} <a href="test.php?dopost=del&id={$dbobj->id}">[删除]</a><br>";                }            }      //下面是del这个post的判断:      empty($dopost)? "" : $dopost;      if($dopost == "save"){          //如果执行插入操作          $sql = "INSERT INTO `dede_test` (`name`) VALUES ('{$name}')";          $dsql->ExecuteNoneQuery($sql);          $lastInsertID = $dsql->GetLastID();          ShowMsg("成功增加一条记录内容!","test.php?id={$lastInsertID}");          exit();      }elseif($dopost == "del"){          //如果dopost为del,则删除数据          $id = isset($id) && is_numeric($id) ? $id : 0;          $sql = "DELETE FROM `dede_test` WHERE (`id`='{$id}')";          $dsql->ExecuteNoneQuery($sql);          ShowMsg("成功删除一条记录内容!","test.php");          exit();      }

以上就是织梦DedeCMS数据库类操作的全部过程,如果有不明白的地方,可以去查看天涯版主的原文,原文的地址如下:http://www.dedecms.com/help/development/2009/1028/1076.html。

转载于:https://www.cnblogs.com/xihong2014/p/4600419.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/257139.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

留言板

本软件是作为部门内员工之间留言及发送消息使用。 系统必须通过口令验证&#xff0c;登录进入。方法是从数据库内取出用户姓名和口令的数据进行校验。 系统包含四部分功能 1 登录&#xff1a;验证用户名与口令&#xff0c;保存会话信息&#xff0c;进入主界面。 界面显示代码 &…

2017-2018-1 20155301 《信息安全系统设计基础》第7周学习总结

2017-2018-1 20155301 《信息安全系统设计基础》第7周学习总结 教材学习内容总结 作为我们处理器实现的运行实例&#xff0c;因为受x86-64指令集的启发&#xff0c;它被俗称为“x86”&#xff0c;所以我们称我们的指令集为“Y86-64”&#xff0c;与“x86-64”相比&#xff0c;Y…

Dubbo原理解析-监控

Dubbo发布代码中&#xff0c;自带了一个简易的监控中心实现。对于一般的小业务这个监控中心应该能够满足需求&#xff0c;对于那些大业务量的大公司一般都会有自己的监控中心&#xff0c;更加丰富的功能如常用的报警短信通知等等。这章讲解分析使得读者能够了解一般的监控中心实…

学习笔记(04):Python网络编程并发编程-什么是socket

立即学习:https://edu.csdn.net/course/play/24458/296233?utm_sourceblogtoedu 1.什么是网络编程&#xff1f; 答&#xff1a;网络编程也叫做socket编程即套接字编程&#xff0c;基于遵循socket套接字的规定进行的编程 2.什么是socket&#xff1f; 答&#xff1a;socket就是…

JeeSite 4.0 说说前端的那些事

2019独角兽企业重金招聘Python工程师标准>>> 引言 一个不得不说的话题&#xff0c;经过近几年的发展&#xff0c;Web前端开发已经不是一个新有的岗位了&#xff0c;前端技术发展非常迅速&#xff0c;技术更新换代也很快&#xff0c;对于前端工程师来说是一个很大的挑…

程序包com.sun.istack.internal不存在

添加一下依赖 <!-- https://mvnrepository.com/artifact/com.sun.xml.bind/jaxb-impl --><dependency> <groupId>com.sun.xml.bind</groupId> <artifactId>jaxb-impl</artifactId> <version>2.2.11</version></dependency&…

iOS微博项目(七)发微博和定位

class a导入class b&#xff0c;class b导入class a 会出现错误 如果keyboard不显示&#xff0c;应该是hardware-》connect选择了 1. 发微博UI 2.定位 一直不回调&#xff0c;后来发现是ios8后方法更新了&#xff1a;http://blog.devzeng.com/blog/ios8-corelocation-framework…

设计模式之UML类图

在学设计模式的过程中经常碰到各式各样的UML类图。那些眼花缭乱的符号有什么含义呢&#xff1f; 类图含义 类图中的关系 从网上找来一张图作为实例 依赖关系&#xff1a;比如动物依赖氧气和水&#xff0c;这里如学生要依赖自行车。用虚线箭头表示。关联关系&#xff1a;学生和身…

tomcat启动报:No Spring WebApplicationInitializer types detected on classpath

2019独角兽企业重金招聘Python工程师标准>>> 对于maven项目&#xff0c;tomcat启动不加载spring配置文件&#xff0c;是因为找不到web.xml文件 右键项目properties 选择 Deployment Assembly 编辑 Web Deployment Assembly&#xff0c;注意主要是红色线框中的路径 …

Linux-正则表达式学习(精)

正则表达式30分钟入门教程 来园子之前写的一篇正则表达式教程&#xff0c;部分翻译自codeproject的The 30 Minute Regex Tutorial。 由于评论里有过长的URL,所以本页排版比较混乱,推荐你到原处查看,看完了如果有问题,再到这里来提出. 一些要说的话&#xff1a; 如果你没有正则表…

Flume sink=avro rpc connection error

要求 conf 文件 a1.sourcesr1 a1.sinksk1 a1.channelsc1a1.sources.r1.typeavro a1.sources.r1.bindmaster a1.sources.r1.port9999a1.sinks.k1.typeavro a1.sinks.k1.hostnameslave1 a1.sinks.k1.port7777a1.channels.c1.typememory a1.channels.c1.capacity1000 a1.channels.…

【腾许Bugly干货分享】“HTTPS”安全在哪里?

背景 最近基于兴趣学学习了下 HTTPS 相关的知识&#xff0c;在此记录下学习心得。 在上网获取信息的过程中&#xff0c;我们接触最多的信息加密传输方式也莫过于 HTTPS 了。每当访问一个站点&#xff0c;浏览器的地址栏中出现绿色图标时&#xff0c;意味着该站点支持 HTTPS 信息…

CCNP精粹系列之十八--路由映射实战二,博主推荐文章

路由映射实战二 本篇博文和上一篇是紧密结合的&#xff0c;只是在上个试验的基础上作了改动&#xff0c;达到其他的试验效果。试验二&#xff1a;在R1上增加一个网段&#xff0c;并发布路由。这里采用三种方法。 如下是第一种&#xff0c;是在试验一的基础上直接增加一个网段&a…

【JUC】JDK1.8源码分析之ConcurrentLinkedQueue(五)

一、前言 接着前面的分析&#xff0c;接下来分析ConcurrentLinkedQueue&#xff0c;ConcurerntLinkedQueue一个基于链接节点的无界线程安全队列。此队列按照 FIFO&#xff08;先进先出&#xff09;原则对元素进行排序。队列的头部是队列中时间最长的元素。队列的尾部 是队列中时…

学习笔记(10):Python网络编程并发编程-粘包现象

立即学习:https://edu.csdn.net/course/play/24458/296240?utm_sourceblogtoedu粘包现象&#xff1a;服务器接收到客户端的命令后&#xff0c;进行执行得到结果后&#xff0c;再发送回给客户端&#xff0c;在这个过程中如果服务器返回的结果的字节数会大于客户端所接收最大字节…

学习笔记(11):Python网络编程并发编程-粘包底层原理分析

立即学习:https://edu.csdn.net/course/play/24458/296241?utm_sourceblogtoedu1.send和recv底层分析 1&#xff09;不管是recv还是send都不是直接接收对方数据或者发送给对方数据&#xff0c;而是对自己的操作系统内存进行操作&#xff1b; 2&#xff09;客户端与服务端并不是…

VMware内存回收与分配机质

VMware内存回收与分配机质 整理了下学习过的东西&#xff0c;为了防止以后忘记。^_^VMware内存回收按照内存回收先后顺充&#xff0c;依次为&#xff1a;1.TPS 透明页共享2.Ballooning 气球回收3.Compressiong 内存压缩4.Swapping 内存交换网上对这个的解释也挺多&#xff…

关于for循环中的变量int i 如果跳出了这个for循环后,i的值是继续保留还是被释放掉了

#include<iostream> using namespace std;int main() {char a[10]; //定义一个一维数组用来存放字符串int i,j; //定义变量cout<<"请输入字符&#xff1a;“;for(i0;i<10;i) //接收用户的输入{ ci…

C#多态

C#多态 多态性&#xff08;C# 编程指南&#xff09;转自MSDN通过继承&#xff0c;一个类可以用作多种类型&#xff1a;可以用作它自己的类型、任何基类型&#xff0c;或者在实现接口时用作任何接口类型。这称为多态性。C# 中的每种类型都是多态的。类型可用作它们自己的类型或用…

C#项目中常用到的设计模式

C#项目中常用到的设计模式 1. 引言 一个项目的通常都是从Demo开始&#xff0c;不断为项目添加新的功能以及重构&#xff0c;也许刚开始的时候代码显得非常凌乱&#xff0c;毫无设计可言。但是随着项目的迭代&#xff0c;往往需要将很多相同功能的代码抽取出来&#xff0c;这也是…