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

spirit1086

  • Осваиваюсь на форуме
  • 120
  • 1
Здравствуйте, как получить id вставленной записи в админской части. Далее используем этот id для вставки в другую таблицу.
Для сохранения использую данную функцию в модели.
Код
public function save($data)
    {
        if (parent::save($data))
{
            return true;
        }

        return false;   
    }
*

vipiusss

  • Профи
  • 5618
  • 322
  • Круглая ава-зло!
Re: получить id вставленной записи
« Ответ #1 : 01.01.2016, 18:38:12 »
public function save($key = null, $urlVar = null){
    if($_POST['jform']){
        foreach($_POST['jform'] as $key=>&$data){
            $value = trim($data);
        }}}
может чото не прав, не особо смотрел, вроде ровно

только для БД таблицу надо.вы решите что именно вы хотите очередное.
jform= ваша форма в любом виде, хоть в диве, можно в ленгвиче через файл.
« Последнее редактирование: 01.01.2016, 18:46:44 от vipiusss »
Миграция, установка, обновление версий Joomla  |  Создание сайтов "под ключ"  |  Эксклюзивные заглушки "offline"  |  Работа с "напильником" над шаблонами и расширениями
*

Aleks.Denezh

  • Практически профи
  • 2806
  • 377
Re: получить id вставленной записи
« Ответ #2 : 01.01.2016, 20:34:46 »
Полностью скопируйте метод save из родителя к себе в модель:
там код что то типа:
Спойлер
[свернуть]

после if (!$table->store()){} id вставленной записи будет в $table->id! и можете его использовать где вам нужно!
Мой  блог по разработке на Joomla CMS!
Хотите отблагодарить материально? Мой WMR: R861060179016
*

yunoshev

  • Разработчик расширений для Joomla 1.0
  • 1239
  • 175
Re: получить id вставленной записи
« Ответ #3 : 02.01.2016, 21:48:08 »
@spirit1086
Можно немного не так, если вам не нужны все эти строки:
Код: php
public function save($data)
    {
        if (parent::save($data))
{
            // узнаем ID
            $insertID = $this->getDbo()->insertid();
            // делаем здесь свои операции
            ...
            return true;
        }

        return false;   
    }
*

Aleks.Denezh

  • Практически профи
  • 2806
  • 377
Re: получить id вставленной записи
« Ответ #4 : 02.01.2016, 22:37:28 »
@spirit1086
Можно немного не так, если вам не нужны все эти строки:

Не очень такой вариант, ибо если какой то плагин отработает и вставит что то дополнительно, то вернет не тот ID...
Мой  блог по разработке на Joomla CMS!
Хотите отблагодарить материально? Мой WMR: R861060179016
*

yunoshev

  • Разработчик расширений для Joomla 1.0
  • 1239
  • 175
Re: получить id вставленной записи
« Ответ #5 : 02.01.2016, 23:46:34 »
@Istaan
В своем варианте он не использует триггеры событий до сохранения и после, поэтому в его случае этого вполне достаточно. Для вашего варианта да, может быть с неверным ID, поэтому я и написал "если не нужны все эти строки".
*

dmitry_stas

  • Профи
  • 10032
  • 952
Re: получить id вставленной записи
« Ответ #6 : 03.01.2016, 00:00:15 »
так ведь они (триггеры) в parent::save сработают же
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

Aleks.Denezh

  • Практически профи
  • 2806
  • 377
Re: получить id вставленной записи
« Ответ #7 : 03.01.2016, 00:03:17 »
@Istaan
В своем варианте он не использует триггеры событий до сохранения и после, поэтому в его случае этого вполне достаточно. Для вашего варианта да, может быть с неверным ID, поэтому я и написал "если не нужны все эти строки".
триггеры вызывается в родителе как бы!
Мой  блог по разработке на Joomla CMS!
Хотите отблагодарить материально? Мой WMR: R861060179016
*

yunoshev

  • Разработчик расширений для Joomla 1.0
  • 1239
  • 175
Re: получить id вставленной записи
« Ответ #8 : 03.01.2016, 00:20:58 »
@Istaan
Блин, вы правы. Это же legacy JModelAdmin... почему почти все компоненты используют эти старые модели? :)
*

b2z

  • Support Team
  • 7469
  • 742
  • Разраблю понемногу
Re: получить id вставленной записи
« Ответ #9 : 19.01.2016, 17:21:16 »
@Istaan
Блин, вы правы. Это же legacy JModelAdmin... почему почти все компоненты используют эти старые модели? :)
А почему нет?
*

yunoshev

  • Разработчик расширений для Joomla 1.0
  • 1239
  • 175
Re: получить id вставленной записи
« Ответ #10 : 19.01.2016, 18:54:51 »
@b2z
Потому что мне понравился новый подход в работе с "родными" J!3.x контроллерами-моделями, который использует компонент com_config. Взял на вооружение при рефакторинге своего магазина под J!3, немного доработав под свои нужды.
И мне кажется, что в дальнейшем Joomla будет развиваться в этом ключе.
*

b2z

  • Support Team
  • 7469
  • 742
  • Разраблю понемногу
*

SmokerMan

  • Профи
  • 5333
  • 689
Re: получить id вставленной записи
« Ответ #12 : 20.01.2016, 13:52:46 »
Код
$this->setState($this->getName(). '.id', $table->$pkName);
Код
public function save($data)
    {
        if (parent::save($data))
{
            // узнаем ID
            $insertID = $this->getState($this->getName(). '.id');
            // делаем здесь свои операции
            ...
            return true;
        }
 
        return false;  
    }
*

AlekVolsk

  • Профи
  • 6312
  • 336
Re: получить id вставленной записи
« Ответ #13 : 21.01.2016, 09:16:04 »
Да, только вот подход опять поменяется в J4. Там будет хорошая революция ;)
пруф?
*

dmitry_stas

  • Профи
  • 10032
  • 952
Re: получить id вставленной записи
« Ответ #14 : 21.01.2016, 10:02:40 »
Да, только вот подход опять поменяется в J4. Там будет хорошая революция ;)
пощупать бы хотя бы альфу...
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Получить данные AJAX в контроллере и направить их в модель для записи в бд

Автор donpekc

Ответов: 6
Просмотров: 299
Последний ответ 24.04.2017, 12:04:52
от donpekc
[Решено] Получить в MODAL виде фильтры из вызывающего вида

Автор platonische

Ответов: 23
Просмотров: 335
Последний ответ 29.03.2017, 13:08:35
от platonische
как грамотно получить другие данные из view?

Автор tm2010

Ответов: 2
Просмотров: 197
Последний ответ 20.02.2017, 23:37:31
от beliyadm
Пользовательская форма - редактирование записи

Автор kadett

Ответов: 5
Просмотров: 237
Последний ответ 03.11.2016, 12:17:00
от Septdir
Как получить id записи в компоненте?

Автор vickof

Ответов: 1
Просмотров: 214
Последний ответ 23.06.2016, 09:40:04
от b2z