刚刚开始,这应该是一个简单的,但我找不到一个好的来源,特别是1.5到1.6 / 1.7 / 2.5的转换。
构建组件以及其他问题不断遇到语法问题。
例如,这是我构建查询的一种方式: [TYPE 1]
$query->SELECT('u.id as UserID
, u.name AS Name
, uppi.profile_value AS Hair
, uppi2.profile_value AS Height
');
$query->FROM (' #__users AS u');
$query->LEFTJOIN (' #__user_profiles AS uppi ON u.id = uppi.user_id AND uppi.ordering = 1 ');
$query->LEFTJOIN (' #__user_profiles AS uppi2 ON u.id = uppi2.user_id AND uppi2.ordering = 2 ');
$query->GROUPBY (' u.id
, u.name
, uppi.profile_value
');
另一种方式: [TYPE 2]
$query->SELECT('u.id as UserID
, u.name AS Name
, uppi.profile_value AS Hair
, uppi2.profile_value AS Height
')
->FROM (' #__users AS u')
->LEFTJOIN (' #__user_profiles AS uppi ON u.id = uppi.user_id AND uppi.ordering = 1 ')
->LEFTJOIN (' #__user_profiles AS uppi2 ON u.id = uppi2.user_id AND uppi2.ordering = 2 ')
->GROUPBY (' u.id
, u.name
, uppi.profile_value
');
关于这两者的混淆部分是像“LEFTJOIN”这样的mysql调用是一个单词而不是两个单词。那么如果我想使用INSERT…ON DUPLICATE KEY UPDATE
,我就完全迷失了。
这是第三个: [TYPE 3]
$query->SELECT('u.id as UserID
, u.name AS Name
, uppi.profile_value AS Hair
, uppi2.profile_value AS Height
');
$query->FROM (' #__users AS u');
$query->JOIN ('LEFT', ' #__user_profiles AS uppi ON u.id = uppi.user_id AND uppi.ordering = 1 ');
$query->JOIN ('LEFT', ' #__user_profiles AS uppi2 ON u.id = uppi2.user_id AND uppi2.ordering = 2 ');
$query->GROUPBY (' u.id
, u.name
, uppi.profile_value
');
$query->ORDER ('u.name ASC');
这是我看到构建查询但无法开始工作的另一种方式[已编辑 - 现在正在工作,感谢@cppl!] [类型4]
$query= "SELECT `u`.`id` as UserID
, `u`.`name` AS Name
, `uppi`.`profile_value` AS Hair
, `uppi2`.`profile_value` AS Height
FROM `#__users` AS u
LEFT JOIN `#__user_profiles` AS uppi ON `u`.`id` = `uppi`.`user_id` AND `uppi`.`ordering` = 1
LEFT JOIN `#__user_profiles` AS uppi2 ON `u`.`id` = `uppi2`.`user_id` AND `uppi2`.`ordering` = 2
";
我已经阅读了Joomla MVC教程和Lynda ......除了“这里有一些代码 - PLOP”之外,没有人能真正解决这个问题。
References:
--//www.theartofjoomla.com/home/9-developer/135-database-upgrades-in-joomla-16.html
--//stackoverflow.com/questions/8467858/joomla-1-7-db-query-does-not-work-when-query-has-an-ampersand
--developer.joomla.org/standards/ch03s10.html
--forum.joomla.org/viewtopic.php?p=2506722
--forum.joomla.org/viewtopic.php?p=1200668
--docs.joomla.org/API16:JDatabaseQuery
--//fsadventures.com/2011/01/some-basic-joomla-database-call-functions/
--//www.sourcecodester.com/php/3863/updating-multiple-rows-mysql-using-php.html
--//stackoverflow.com/questions/7047471/mysql-query-syntax-error
问题:
1)这些之间是否存在差异?
2)是否有理由使用一种方法而不是另一种方法?
3)是否有很好的资源来学习不同的构建方法?我搜索了几个小时,但没有发现任何全面的内容。
谢谢!
答案 0 :(得分:2)
$query
对象具有select()
,where()
,join()
等功能的原因等等... ->leftJoin()
是对JDatabaseQuery函数的一个名为leftJoin()
的PHP调用,因此必须是一个单词即。它不能是两个。leftJoin()
实际上只是调用join('LEFT',$conditions)
所以它是一个可读性实现而不是功能差异。您似乎找到了Joomla的所有在线资源!文档,除了Joomla! Google网上论坛(CMS Dev,General Dev和Platform Dev)。
唯一的另一个来源是Andrew Eddies“Learn the Art of Joomla!”。我自己没有使用安德鲁的东西,但我听说过很多关于它的好东西,最后一个Joomla!我参加的那天。
修改强>
根据错误,我会说这是因为您将标识符u.id
封装为一个标识符。尝试类似:
SELECT `u`.`id` AS "UserID" FROM `#__users` AS `u`