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

CaHeK_pk

  • Захожу иногда
  • 114
  • 2 / 0
SQL работа с массивом
« : 23.09.2015, 15:13:09 »
Добрый день, нужно добавить значения в определенную строку в которой хранится вот это
Код: sql
{"hideempty":"1","color":"FFFFFF",
"mirror_module":"0","mirror_moduleid":"132","match_method":"or","show_assignments":"1","assignto_menuitems":"0",
"assignto_menuitems_selection":["159","173"],"assignto_menuitems_inc_children":"1","assignto_menuitems_inc_noitemid":"0",
"assignto_homepage":"0",
"assignto_date":"0","assignto_date_publish_up":"0000-00-00 00:00",
"assignto_date_publish_down":"0000-00-00 00:00","assignto_date_recurring":"0","assignto_seasons":"0",
"assignto_seasons_selection":["x"],"assignto_seasons_hemisphere":"northern","assignto_months":"0","assignto_months_selection":["x"],"assignto_days":"0","assignto_days_selection":["x"],"assignto_time":"0","assignto_time_publish_up":"0:00","assignto_time_publish_down":"0:00","assignto_usergrouplevels":"0",
"assignto_users":"0","assignto_users_selection":"","assignto_languages":"0","assignto_ips":"0","assignto_ips_selection":"",
"assignto_geocontinents":"0","assignto_geocountries":"0","assignto_georegions":"0","assignto_templates":"0","assignto_urls":"0",
"assignto_urls_selection":"","assignto_urls_regex":"0","assignto_os":"0","assignto_browsers":"0","assignto_components":"0",
"assignto_contentpagetypes":"0","assignto_cats":"0","assignto_cats_inc_children":"0","assignto_cats_inc":["inc_cats","inc_arts","x"],"assignto_articles":"0","assignto_articles_keywords":"","assignto_virtuemartpagetypes":"1",
"assignto_virtuemartcats":"1","assignto_virtuemartcats_inc_children":"0","assignto_virtuemartcats_inc":["inc_cats","x"],"assignto_virtuemartproducts":"2",
"assignto_virtuemartproducts_selection":["31","31","[color=red][b]Вот сюда добавляем id с номером материала[/b][/color]","25","31","25","29","24","24","27","27","23","23","30","30"],
"assignto_php":"2","assignto_php_selection":""}
при помощи php скрипта... как это можно сделать, если обычным методом update, то всю эту строку перезаписывает...
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: SQL работа с массивом
« Ответ #1 : 23.09.2015, 15:24:13 »
В SET надо писать
Код
set `fieldname` = CONCAT(`fieldname`, 'new string value')
*

CaHeK_pk

  • Захожу иногда
  • 114
  • 2 / 0
Re: SQL работа с массивом
« Ответ #2 : 23.09.2015, 15:41:41 »
В SET надо писать
Код
set `fieldname` = CONCAT(`fieldname`, 'new string value')
Благодарю, но можете полностью запрос прописать, с SET ни-разу не работал просто.
получается нужно поменять строку "params" где "moduleid = 132", как раз в "params"  находится тот код который указывал в первом посте, благодарю заранее за помощь
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: SQL работа с массивом
« Ответ #3 : 23.09.2015, 19:09:43 »
Вы писали "если обычным методом update", каким методом вы делали?
*

CaHeK_pk

  • Захожу иногда
  • 114
  • 2 / 0
Re: SQL работа с массивом
« Ответ #4 : 24.09.2015, 05:03:54 »
Вы писали "если обычным методом update", каким методом вы делали?
Код: sql
UPDATE  `kamsales_new`.`kmsls_advancedmodules` SET  `params` = CONCAT('assignto_virtuemartproducts', '25') WHERE `kmsls_advancedmodules`.`moduleid` =161;
что не так делаю? по итогу в записи все заменяется на "assignto_virtuemartproducts1"...
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: SQL работа с массивом
« Ответ #5 : 24.09.2015, 06:12:58 »
Прямые кавычки обрамляют строку, название поля принято обрамлять ` или вообще не обрамлять.
*

CaHeK_pk

  • Захожу иногда
  • 114
  • 2 / 0
Re: SQL работа с массивом
« Ответ #6 : 24.09.2015, 06:55:25 »
Прямые кавычки обрамляют строку, название поля принято обрамлять ` или вообще не обрамлять.
Код: sql
UPDATE  `kamsales_new`.`kmsls_advancedmodules` SET  `params` = CONCAT(`assignto_virtuemartproducts_selection`, '25') WHERE `kmsls_advancedmodules`.`moduleid` =161;
пишет
#1054 - Unknown column 'assignto_virtuemartproducts' in 'field list'
понять не могу что не так
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: SQL работа с массивом
« Ответ #7 : 24.09.2015, 16:19:48 »
Пишет что такой ячейки нет в этой таблице. Но в запросе и в ошибке разные ячейки.
*

CaHeK_pk

  • Захожу иногда
  • 114
  • 2 / 0
Re: SQL работа с массивом
« Ответ #8 : 28.09.2015, 12:24:10 »
Пишет что такой ячейки нет в этой таблице. Но в запросе и в ошибке разные ячейки.
это да, просто запросы разные делал, вообщем ничего не выходит увы...
наглядно как выглядит структура таблицы, может тогда подскажете
moduleid | asset_id | params |
------------------------------------
161        | 291        | здесь и производим изменеия
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: SQL работа с массивом
« Ответ #9 : 29.09.2015, 05:51:12 »
Код: sql
UPDATE  `kamsales_new` SET  `params` = CONCAT(`params`, ' 25') WHERE `moduleid` =161;
И не говорите что не работает, проверил, все работает.
*

CaHeK_pk

  • Захожу иногда
  • 114
  • 2 / 0
Re: SQL работа с массивом
« Ответ #10 : 29.09.2015, 08:10:12 »
Код: sql
UPDATE  `kamsales_new` SET  `params` = CONCAT(`params`, ' 25') WHERE `moduleid` =161;
И не говорите что не работает, проверил, все работает.
ну а как добавить именно в определенное место?
Код: sql
.....,"assignto_virtuemartcats_inc_children":"0","assignto_virtuemartcats_inc":["inc_cats","x"],"assignto_virtuemartproducts":"2",

"assignto_virtuemartproducts_selection":["31","31","Вот сюда добавляем id с номером материала","25","31","25","29","24","24","27","27","23","23","30","30"],

"assignto_php":"2","assignto_php_selection":""}
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: SQL работа с массивом
« Ответ #11 : 29.09.2015, 08:22:58 »
Запрашивайте поле, обрататывайте его в php, пишите обратно без всяких конкатенаций.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Непонятная работа плагина "Поиск"

Автор Snip

Ответов: 0
Просмотров: 948
Последний ответ 20.03.2023, 10:47:56
от Snip
Работа со сриптами в Joomla

Автор Viclingvolive

Ответов: 3
Просмотров: 1001
Последний ответ 11.12.2019, 04:14:04
от aztekadv
Hotspots или что то другое? (работа с картами)

Автор Governor

Ответов: 3
Просмотров: 2775
Последний ответ 26.03.2018, 06:59:08
от bato
Ищу специалиста для различных изменений на сайтах в модулях за деньги, работа есть

Автор GuN

Ответов: 1
Просмотров: 849
Последний ответ 01.02.2017, 20:05:39
от Septdir
Работа WidgetKit Lite в разных браузерах.

Автор Ser_g

Ответов: 0
Просмотров: 1205
Последний ответ 18.04.2016, 12:35:58
от Ser_g