0 Пользователей и 1 Гость просматривают эту тему.
  • 7 Ответов
  • 3285 Просмотров
*

ANRY_777

  • Осваиваюсь на форуме
  • 25
  • 2 / 0
Помогите при создании компонента.

модель
Код
<?php
Defined ('_JEXEC')  or  die();
jimport( 'joomla.application.component.model' );
 
class TecdocModelArticle extends JModel
{
  
        function getArticle()
        {
 
                $option = array(); //prevent problems
                $option['driver']   = 'mysql';            // Database driver name
                $option['host']     = 'localhost';    // Database host name
                $option['user']     = '***';       // User for database authentication
                $option['password'] = '****';   // Password for database authentication
                $option['database'] = '****';      // Database name
                $option['prefix']   = '';             // Database prefix (may be empty)
                $db = & JDatabase::getInstance( $option );
                $ordering       = 'LA_ART_ID';
                if    (isset($_GET['strid']) and isset($_GET['typida']))
                {
                $STR_ID = $_GET['strid'];
                $TYP_ID = $_GET['typida'];
                }
                $lngid = 16;
                $query = 'SELECT LA_ART_ID'
                                . ' FROM LINK_GA_STR'
                                . ' WHERE LGS_STR_ID ='.$STR_ID
                                . ' ORDER BY '.$ordering
                                ;
                $db->setQuery( $query );
                $LA_ART_ID = $db->loadResult();
                
                
                $ART_ID = $LA_ART_ID;
                $query ='SELECT ART_ARTICLE_NR, SUP_BRAND'
                                . ' FROM ARTICLES'
                                . ' WHERE ART_ID = '.$ART_ID
                                . ' AND DESIGNATIONS.DES_LNG_ID ='.$lngid
                                ;              
                $db->setQuery( $query );
                $articlelist = $db->loadObjectList();
                
                return $articlelist;
        }
}

сечас при етом коде выводитса одно значение из базы  ARTICLES  а надо щоб било много. Тоисть здесь
Код
$LA_ART_ID = $db->loadResult();
надо прописать loadObjectList и етот код
Код
$ART_ID = $LA_ART_ID;
                $query ='SELECT ART_ARTICLE_NR, SUP_BRAND'
                                . ' FROM ARTICLES'
                                . ' WHERE ART_ID = '.$ART_ID
                                . ' AND DESIGNATIONS.DES_LNG_ID ='.$lngid
                                ;              
                $db->setQuery( $query );
                $articlelist = $db->loadObjectList();

записать в цыкле пример
Код
foreach($LA_ART_ID as $LA_ART_ID) 
{
$ART_ID = $LA_ART_ID
}

чтобы переменная $ART_ID изменялась при каждом наступном
Код
$ART_ID = $LA_ART_ID;
                $query ='SELECT ART_ARTICLE_NR, SUP_BRAND'
                                . ' FROM ARTICLES'
                                . ' WHERE ART_ID = '.$ART_ID
                                . ' AND DESIGNATIONS.DES_LNG_ID ='.$lngid
                                ;              
                $db->setQuery( $query );
                $articlelist = $db->loadObjectList();


и в $articlelist попал весь масив





я понимаю как прописать на РНР час покажу НО не понимаю как вивести дание масива в joomla
Код
<? 
 
$result = mysql_query("
SELECT LA_ART_ID
FROM LINK_GA_STR
WHERE LGS_STR_ID = '$STR_ID' ",$db);
do {

$ART_ID = $myrow["LA_ART_ID"];
$LNG_ID = 16;

$result2= mysql_query("
SELECT ART_ARTICLE_NR, SUP_BRAND,
FROM ARTICLES
WHERE ART_ID = '$ART_ID' ",$db);

do {

printf ("", $myrow2["SUP_BRAND"] , $myrow2["ART_ARTICLE_NR"]);
}
while ($myrow2 = mysql_fetch_array($result2));
}

while ($myrow = mysql_fetch_array($result));

?>

Помогите пожалуйста.



*

b2z

  • Глобальный модератор
  • 7212
  • 777 / 0
  • Разраблю понемногу
Re: Создание компонента! Joomla 1.5 MVC!
« Ответ #1 : 23.02.2011, 11:01:27 »
1. Ваш код потенциально подвержен SQL инъекции. Советую фильтровать переменные, которые Вы получаете  из $_GET и пользоваться при этом встроенными Joomla методами:
http://docs.joomla.org/Retrieving_data_from_GET_and_POST_requests

2. Честно, мне непонятна логика построения Вашей базы данных. Из того, что я вижу - она некорректна.

Из таблицы LINK_GA_STR Вы выбираете ОДИН конкртеный ID статьи LA_ART_ID, который принадлежит какой-то LGS_STR_ID. Затем Вы по этой LA_ART_ID выбираете из таблицы статей ARTICLES эту статью. Логично, что так будет делаться выборка только одной статьи и никак по другому тут не сделаешь.

3. То, что Вы предлагаете делать - это делать SELECT в цикле, и это в корне неверно. Вам нужно поменть логику построения базы данных, связей между таблицами.
*

ANRY_777

  • Осваиваюсь на форуме
  • 25
  • 2 / 0
Re: Создание компонента! Joomla 1.5 MVC!
« Ответ #2 : 23.02.2011, 11:31:21 »
Из таблицы LINK_GA_STR Вы выбираете ОДИН конкртеный ID статьи LA_ART_ID, который принадлежит какой-то LGS_STR_ID. Затем Вы по этой LA_ART_ID выбираете из таблицы статей ARTICLES эту статью. Логично, что так будет делаться выборка только одной статьи и никак по другому тут не сделаешь.

Вы все правильно поняли! Только мне нужно из таблицы LINK_GA_STR
выбрать много ID. Если прописать $ db-> loadObjectList (); я получаю массив. Здесь все хорошо!

Теперь мне нужно по этому массиву который я получил, из таблицы артикулов товара ARTICLES по LA_ART_ID равное ART_ID
выбрать также массив уже немножко других артикулов с названиями товара и описанием.

если прописать
Код
$query = 'SELECT LA_ART_ID'
                                . ' FROM LINK_GA_STR'
                                . ' WHERE LGS_STR_ID ='.$STR_ID
                                . ' ORDER BY '.$ordering
                                ;
                $db->setQuery( $query );
                $LA_ART_ID = [b]$db->loadResult();[/b]
             
                $ART_ID = $LA_ART_ID;
                $query ='SELECT ART_ARTICLE_NR, SUP_BRAND'
                                . ' FROM ARTICLES'
                                . ' WHERE ART_ID = '.$ART_ID
                                . ' AND DESIGNATIONS.DES_LNG_ID ='.$lngid
                                ;               
                $db->setQuery( $query );
                $articlelist = $db->loadObjectList();                 
                return $articlelist;

то выводится только один артикул с описанием товара. А должно быть много!
я понимаю что нужно из таблицы LINK_GA_STR выбрать массив с помощью $ db-> loadObjectList ()

но как потом по массиву пройти чтобы выполнить второй запрос и чтобы он также вытащил массив.
где уже $ART_ID = $LA_ART_ID а $LA_ART_ID по очереди перебраные елементи масыва из первова запроса.
Код
$ART_ID = $LA_ART_ID;
                $query ='SELECT ART_ARTICLE_NR, SUP_BRAND'
                                . ' FROM ARTICLES'
                                . ' WHERE ART_ID = '.$ART_ID
                                . ' AND DESIGNATIONS.DES_LNG_ID ='.$lngid
                                ;               
                $db->setQuery( $query );
                $articlelist = $db->loadObjectList();

*

ANRY_777

  • Осваиваюсь на форуме
  • 25
  • 2 / 0
Re: Создание компонента! Joomla 1.5 MVC!
« Ответ #3 : 23.02.2011, 11:36:26 »
я не могу изменить структуру базы. Я ее не создавал я ее только купил! На сайте на РНР это все я реализовал. хотелось создать компонент для Joomla
*

b2z

  • Глобальный модератор
  • 7212
  • 777 / 0
  • Разраблю понемногу
Re: Создание компонента! Joomla 1.5 MVC!
« Ответ #4 : 23.02.2011, 12:51:25 »
Вообщем, если Вы хотите делать так криво, тогда вот:

Код
$db->setQuery($query);
$LA_ART_ID = $db->loadObjectList();

// проход по массиву
foreach ($LA_ART_ID as $lartId)
{
               $query = 'SELECT ... WHERE ART_ID = '.$lartId->id;
}
$db->setQuery($query);
$articlelist = $db->loadObjectList();                
return $articlelist;

Но это конечно жестокий метод - это просто убийца базы.

Наверное можно ещё решить с помощью вложенных запросов

Код
$query ='SELECT ART_ARTICLE_NR, SUP_BRAND'
. ' FROM ARTICLES'
. ' WHERE ART_ID = (SELECT LA_ART_ID'
. ' FROM LINK_GA_STR'
. ' WHERE LGS_STR_ID ='.$STR_ID)
. ' AND DESIGNATIONS.DES_LNG_ID ='.$lngid
. ' ORDER BY '.$ordering
;  

За точность и правильность не отчечаю, но идея должна быть понятна. В любом случае это все очень плохое программирование.
*

ANRY_777

  • Осваиваюсь на форуме
  • 25
  • 2 / 0
Re: Создание компонента! Joomla 1.5 MVC!
« Ответ #5 : 23.02.2011, 14:44:13 »
Выводит только один элемент (артикул).
в $ articlelist попадает лишь один артикул. потому что foreach () проходит массив $ LA_ART_ID и в конце в переменную $ query попадает строка где $ lartId-> id имеет последний элемент из массива $ LA_ART_ID.

нужно взять код
$ db-> setQuery ($ query);
$ articlelist = $ db-> loadObjectList ();

также в цикл или прописать чтобы в $ articlelist в цикле дописовались элементы
*

b2z

  • Глобальный модератор
  • 7212
  • 777 / 0
  • Разраблю понемногу
Re: Создание компонента! Joomla 1.5 MVC!
« Ответ #6 : 23.02.2011, 16:13:46 »
Хе, тогда так:


foreach ($LA_ART_ID as $lartId)
{
$query 'SELECT ... WHERE ART_ID = '.$lartId->id;
$db->setQuery($query);
$article $db->loadObject();
$articlelist[]['SUP_BRAND'] = $article->SUP_BRAND;
$articlelist[]['ART_ARTICLE_NR'] = $article->ART_ARTICLE_NR;
}


Извращение не знает границ  ;D
*

ANRY_777

  • Осваиваюсь на форуме
  • 25
  • 2 / 0
Re: Создание компонента! Joomla 1.5 MVC!
« Ответ #7 : 23.02.2011, 18:58:30 »
Всьоравно плохо ((
код файла default.php
Код
<?php  
defined('_JEXEC') or die('Restricted access');
?>
<table width="100%" cellspacing="0" cellpadding="0" border="0" style="margin-bottom:15px;">
<tr align="left" class="sectiontableheader">
        <td width="16%"><?php echo JText::_( 'NUMBER' ); ?></td>
        <td width="10%"><?php echo JText::_( 'DESCRIPTION' );?></td>
</tr>
<? foreach($this->article as $article)
{
?>

<tr id="tableheader_tr">
        <td><?php echo $article['ART_ARTICLE_NR']; ?></td>
        <td><?php echo $article['ART_COMPLETE_DES_TEXT']; ?></td>
</tr>

<? } ?>
</table>

и фрагмент кода как виводить!
Код
<table width="100%" cellspacing="0" cellpadding="0" border="0" style="margin-bottom:15px;">

<tr align="left" class="sectiontableheader">

        <td width="16%"> Номер</td>

        <td width="10%"> Опис</td>

</tr>



<tr id="tableheader_tr">

        <td></td>

        <td></td>

</tr>





<tr id="tableheader_tr">

        <td>1433G</td>

        <td></td>

</tr>





<tr id="tableheader_tr">

        <td></td>

        <td>Амортизатор</td>

</tr>





<tr id="tableheader_tr">

        <td></td>

        <td></td>

</tr>





<tr id="tableheader_tr">

        <td>3358DG</td>

        <td></td>

</tr>





<tr id="tableheader_tr">

        <td></td>

        <td>Амортизатор</td>

</tr>

может я не так вивожу в дефаулте переменные.
Виглядит так проходт цикл ы в шаблон подставляет только одну переменною. потом снова толька подставляэт другую ((( может запись в масив $articlelist както поменять ??
Спасибо!






Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Валидация форм средствами Joomla

Автор VETERINAR

Ответов: 29
Просмотров: 35628
Последний ответ 09.10.2013, 15:14:44
от digitalheart
Как написать системный плагин для Joomla 1.5

Автор Sergey2

Ответов: 2
Просмотров: 26949
Последний ответ 23.06.2013, 15:28:38
от l-key
[how to] Красота JHTML, или создание элементов формы с

Автор Professor

Ответов: 11
Просмотров: 21824
Последний ответ 27.12.2012, 18:14:38
от BaR
Плагин рейтинга чего угодно для Joomla 1.5

Автор Obmor

Ответов: 54
Просмотров: 28809
Последний ответ 18.12.2012, 15:01:55
от Raimonds
Как вы "въехали" в создание расширений?

Автор aanvale

Ответов: 4
Просмотров: 1821
Последний ответ 13.10.2012, 21:44:25
от passer