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

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
комрады, помогайте!
застрял с детским вопросом - не могу простой запрос на инкремент поля с хитами написать использую джумловский синтактис
UPD - РЕШЕНО
Код
		$fields = array(
$db->quoteName('hits'). ' = ' . $db->quoteName('hits')+1
);

// Conditions for which records should be updated.
$conditions = array(
$db->quoteName('id'). ' = $aId '
);

$query->update($db->quoteName('#__content'))->set($fields)->where($conditions);
$db->setQuery($query);
$result = $db->execute();
$result = $db->execute();

ошибка где-то тут, но где..
 near '1 WHERE ```id`` = $aId `' at line 2
*

NewUsers

  • Живу я здесь
  • 2307
  • 214 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
Re: Ненавижу джумловский database!
« Ответ #1 : 29.09.2018, 18:09:16 »
Код: php
$db->quoteName('id'). ' = ' .$aId
Занимаюсь создание расширений для Joomla 3.10.x и 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
Работа с DOM деревом на PHP
*

NewUsers

  • Живу я здесь
  • 2307
  • 214 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
Re: Ненавижу джумловский database!
« Ответ #3 : 29.09.2018, 18:18:00 »
не канает, продолжаю ненавидеть   *RTFM*;D
Ну а если вот так!
Код: php
$db = Factory::getDbo();
$query = $db->getQuery(true);

$query->update($db->quoteName('#__content'))
->set($db->quoteName('hits').' = (hits + 1)')
->where($db->quoteName('id'). ' = ' . $aId);
$db->setQuery($query)->execute();
Занимаюсь создание расширений для Joomla 3.10.x и 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
Работа с DOM деревом на PHP
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Ненавижу джумловский database!
« Ответ #5 : 29.09.2018, 18:28:59 »
а почему мы hits и id экранируем, а $aId - нет? :) надо бы наоборот :)

Цитировать
$db -> setQuery(
    $db -> getQuery(true)
          -> update($db->qn('#__content'))
          -> set('hits = hits + 1')
          -> where('id = ' . $db->q($aId))
) -> execute();
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

b2z

  • Глобальный модератор
  • 7290
  • 778 / 0
  • Разраблю понемногу
RE: Ненавижу джумловский database!
« Ответ #6 : 30.09.2018, 09:31:15 »
Достаточно сделать через (int), а так экранируется как строка  ^-^
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
RE: Ненавижу джумловский database!
« Ответ #8 : 30.09.2018, 10:00:16 »
Достаточно сделать через (int), а так экранируется как строка  ^-^
можно и int, не вопрос :)

запости, как будет максимально правильно, пожалуйста.
Код
where('id = ' . (int)$aId)
правильны оба варианта, разницы особо нет.  главное, что данные фильтруются :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
RE: Ненавижу джумловский database!
« Ответ #10 : 13.10.2018, 16:49:25 »
Код
$table = new Joomla\CMS\Table\Content(Joomla\CMS\Factory::getDbo());
$table->hit($aId);
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
RE: Ненавижу джумловский database!
« Ответ #12 : 13.10.2018, 16:58:01 »
Вот сразу видно, что программист зашел: коротко и прекрасно!  *DRINK*
Я не думал что народ не знает что в классе JTable(Новый Table)  есть по умолчанию метод hit который записывает в поле hits + 1
Работает для любой таблицы которая в таком виде..
Можно даже писать если поле назвали не hits у себя в базе, только надо будет алиасы переопределить
Код
$table = new Joomla\CMS\Table\Content(Joomla\CMS\Factory::getDbo());
$table->setColumnAlias('hits', 'my_field_name');
$table->hit($aId);

*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
RE: Ненавижу джумловский database!
« Ответ #13 : 13.10.2018, 17:05:38 »
народ знает. народ не любит юзать JTable без надобности :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
RE: Ненавижу джумловский database!
« Ответ #14 : 13.10.2018, 17:06:56 »
меня, как представителя малограмотного народа, уже слегка напрягает фрагментация джумловских фреймворков.
надеюсь, они выпустят 4-ку и уйдут в продолжительный отпуск  ;D
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
RE: Ненавижу джумловский database!
« Ответ #15 : 13.10.2018, 17:07:11 »
народ знает. народ не любит юзать JTable без надобности :)
ну для таблицы #__content это системный класс )
*

beliyadm

  • Легенда
  • 9758
  • 1664 / 66
  • Севастополь, Россия
RE: Ненавижу джумловский database!
« Ответ #16 : 14.10.2018, 18:51:29 »
а я так и не понимаю, зачем использовать каждый раз меняющиеся классы и операнды, вместо одного лаконичного стандартного SQL запроса, который будет работать с времен мамбы до движка 18.0

Нахрен мне изучать вот это
Код
$table = new Joomla\CMS\Table\Content(Joomla\CMS\Factory::getDbo());
вместо классического
Код
update table set hit = hit+1
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

beliyadm

  • Легенда
  • 9758
  • 1664 / 66
  • Севастополь, Россия
RE: Ненавижу джумловский database!
« Ответ #18 : 14.10.2018, 18:56:22 »
ну не хочется ***кодить
С каких пор ванилла код считается ***кодом? :):)
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

Aleks.Denezh

  • Живу я здесь
  • 3406
  • 428 / 4
RE: Ненавижу джумловский database!
« Ответ #19 : 14.10.2018, 21:28:40 »
а я так и не понимаю, зачем использовать каждый раз меняющиеся классы и операнды, вместо одного лаконичного стандартного SQL запроса, который будет работать с времен мамбы до движка 18.0

Нахрен мне изучать вот это
Код
$table = new Joomla\CMS\Table\Content(Joomla\CMS\Factory::getDbo());
вместо классического
Код
update table set hit = hit+1

Понимаете, если вы пишешь свой компонент, то в 10 раз удобнее в модели написать
Код
$this->getTable('myTable')->hit(123); 
чем простыню )
Метод hit как бы тянется с 1.6 ветки не меняясь )
Но вас никто не заставляет его юзать я просто написал один из вариантов как можно реализовать )
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

[решено] Использование model - setState для фильтра по дате

Автор effrit

Ответов: 8
Просмотров: 1445
Последний ответ 13.10.2018, 19:13:49
от effrit
[Решено] принудительно заполнить поле tags в плагине

Автор Sergeyy

Ответов: 5
Просмотров: 1178
Последний ответ 30.01.2017, 14:40:43
от Sergeyy
[Решено] Создание контент плагина

Автор IvanTopor

Ответов: 4
Просмотров: 1248
Последний ответ 26.02.2016, 13:10:37
от IvanTopor
[Решено] Как заполнить Тег <select> из базы?

Автор кодик

Ответов: 9
Просмотров: 1540
Последний ответ 03.12.2015, 20:42:46
от кодик
[Решено] Проблема с уровнями доступов и передачей переменной id

Автор flash709

Ответов: 18
Просмотров: 1728
Последний ответ 29.01.2015, 10:01:48
от b2z