Joomla Jdatabase select语句不起作用

时间:2014-06-10 12:14:09

标签: mysql joomla

下面的Joomla(3.3)Jdatabase代码(由Fabrik使用)应该在数据库中找到一个名称。该名称以表格(var $ data)提交,其值为“绿色”。

但是,在执行代码时,我收到错误消息:

 1054 - Unknown column 'green' in 'where clause' SQL=SELECT `user_id` FROM `weq_extendedreg_users` WHERE `cf_collectivename` = `green`

Joomla php代码:

$db = JFactory::getDbo();

// Create a new query object.
$query = $db->getQuery(true);
$query->select($db->quoteName('user_id'));
$query->from($db->quoteName('#__extendedreg_users'));
$query->where($db->quoteName('cf_collectivename') . ' = '. $db->quoteName($data)); //use  $data for this form element
$db->setQuery($query);
$db->execute();
$collective_id = $db->loadResult(); //query returns null if fails

//var_dump($data,$collective_id);exit;
return isset($collective_id);

我不明白where语句有什么问题以及为什么代码会认为'表格变量是表格列? (我检查了http://docs.joomla.org/Selecting_data_using_JDatabase

有什么想法吗?

1 个答案:

答案 0 :(得分:2)

试试这个

$db->quote($data) instead of $db->quoteName($data)