首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Joomla3.1 JDatabase联合查询

Joomla3.1 JDatabase联合查询
EN

Stack Overflow用户
提问于 2013-11-20 11:56:21
回答 3查看 1.9K关注 0票数 1

有人能展示如何与jDatabase query对象联合吗?

功能看起来在Joomla中,我只是找不到任何有工作示例的文档.

我想要实现的查询通常以纯文本显示如下:

代码语言:javascript
复制
SELECT field1,field2 FROM `#__mycomponent_table1` WHERE field1 = 0
UNION
SELECT field1,field2 FROM `#__mycomponent_table2` WHERE field1 = 0

编辑-我试过这样做:

代码语言:javascript
复制
$db = $this->getDbo();
$query = $db->getQuery(true);
$query->union(array('SELECT field1,field2 FROM `#__mycomponent_table1` WHERE field1 = 0','SELECT field1,field2 FROM `#__mycomponent_table2` WHERE field1 = 0'));

给我:

您的SQL语法有错误;请检查与您的MySQL服务器版本对应的手册,以获得在第1行SQL=限制0、15 SQL=附近使用的正确语法。

EN

回答 3

Stack Overflow用户

发布于 2013-11-21 10:37:24

不要把UNION和混为一谈

"UNION用于将来自多个SELECT语句的结果组合到单个结果集中。“联合语法

所以,首先,你需要了解你是需要加入还是联盟。

如何在Joomla中使用UNION

从统计上讲,(检查Joomla代码库) UNION并不像JOIN那样被广泛使用。

基本上,Joomla确实为JDatabaseQuery类提供了至少两个方法。unionunionAll.不幸的是,我无法为您提供一个真正有效的查询。

在CMS中使用它的唯一组件是com_finder索引器,如果您想研究它的话。

如果您真的需要,不要害怕普通的旧查询,

虽然使用JDatabaseQuery确实提供了一种构建查询的简单方法,并且还使它们与多个数据库驱动程序兼容,但是如果需要的话,自己编写查询没有什么错,特别是如果您只需要MySQL支持的话。

JDatabase & Co有许多很酷的特性,但绝不完美。它们解决了您拥有的99%的查询需求。在某些情况下,您需要更复杂的表达式,而这些表达式不包括在这些表达式中。

最后,提供给数据库引擎的查询仍然是一个查询,不管它是如何构建的。

票数 1
EN

Stack Overflow用户

发布于 2013-11-20 12:29:43

添加工会查询,如下所示。欲了解更多信息,请访问乔姆拉博士:-

代码语言:javascript
复制
$db = JFactory::getDbo();
$query = "
  SELECT *
    FROM . . . ";
$db->setQuery($query);
$row = $db->loadObjectList();
票数 0
EN

Stack Overflow用户

发布于 2013-11-20 14:52:40

您总是可以像这样使用join()方法:

代码语言:javascript
复制
$db = JFactory::getDbo();
$query = $db->getQuery(true);

$query->select($db->quoteName(array('a.*', 'b.username', 'b.name')))
 ->from($db->quoteName('#__content', 'a'))
 ->join('INNER', $db->quoteName('#__users', 'b') . ' ON (' . $db->quoteName('a.created_by') . ' = ' . $db->quoteName('b.id') . ')')
 ->where($db->quoteName('b.username') . ' LIKE \'a%\'');

$db->setQuery($query);
$rows = $db->loadObjectList();

这只是一个示例查询,它将为用户名以"a"开头的用户选择所有文章。

希望这能有所帮助

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20095293

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档