SQL работа с массивом

  • 11 Ответов
  • 625 Просмотров

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

*

CaHeK_pk

  • Осваиваюсь на форуме
  • ***
  • 115
  • 2
SQL работа с массивом
« : 23.09.2015, 17: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

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

*

CaHeK_pk

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

*

Arkadiy

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

*

CaHeK_pk

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

*

Arkadiy

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

*

CaHeK_pk

  • Осваиваюсь на форуме
  • ***
  • 115
  • 2
Re: SQL работа с массивом
« Ответ #6 : 24.09.2015, 08: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

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

*

CaHeK_pk

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

*

Arkadiy

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

*

CaHeK_pk

  • Осваиваюсь на форуме
  • ***
  • 115
  • 2
Re: SQL работа с массивом
« Ответ #10 : 29.09.2015, 10: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

  • Группа развития
  • *****
  • 5342
  • 440
  • Крепитесь, други.
Re: SQL работа с массивом
« Ответ #11 : 29.09.2015, 10:22:58 »
Запрашивайте поле, обрататывайте его в php, пишите обратно без всяких конкатенаций.