Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: Поиск дубликатов
Форумы портала PHP.SU » » Вопросы новичков » Поиск дубликатов

Страниц (1): [1]
 

1. TurnOff - 16 Июля, 2014 - 11:32:13 - перейти к сообщению
Доброго времени суток, ребята. В общем имеется такая задача. Есть таблицы в mysql, допустим таблица qwerty, с атрибутами titile, image,id. Атрибут titile может быть любым, а вот атрибут image генеритсяю Допустим, есть файл... вы внесли туда изменения, сохранили его под названием file, потом опять его поменяли, но он уже сохранится как file + рандомное число от 10 до 99, то есть file56. И таких названий может быть куча. И разных. Что надо: 1) найти первоначальное имя файла; 2) вывести файл первоначального вида и сбоку вывести все го дубликаты.
Вот так выглядит таблица.
CODE (htmlphp):
скопировать код в буфер обмена
  1. "id"    "title"                 "image"
  2. "158"   "privod_cepn"           "privod_cepn"
  3. "265"   "privod_cepn16"         "privod_cepn16"
  4. "335"   "privod_cepn17"         "privod_cepn17"
  5. "160"   "privod_cepn79"         "privod_cepn79"
  6. "347"   "privod_cepn92"         "privod_cepn92"
  7. "159"   "privod_naval"          "privod_naval"
  8. "336"   "privod_naval56"        "privod_naval56"
  9. "348"   "privod_naval80"        "privod_naval80"
  10. "266"   "privod_naval99"        "privod_naval99"
  11. "301"   "proem_garazh"          "proem_garazh"
  12. "305"   "proem_garazh20"        "proem_garazh20"
  13. "351"   "proem_garazh99"        "proem_garazh99"
2. SAD - 16 Июля, 2014 - 12:29:58 - перейти к сообщению
Ну храните в этой табличке первоначальное имя, а в доп. табличке дубликаты и свяжите таблицы по id
3. TurnOff - 16 Июля, 2014 - 13:27:18 - перейти к сообщению
SAD пишет:
Ну храните в этой табличке первоначальное имя, а в доп. табличке дубликаты и свяжите таблицы по id

Дело в том, что это имена файлов... они располагаются в каталоге. Файлы парсятся и заносится информация в бд. Таблицы трогать нельзя )
4. Panoptik - 16 Июля, 2014 - 13:59:50 - перейти к сообщению
а что можно трогать?
(Добавление)
допустим оригинальный файл можно узнать так

PHP:
скопировать код в буфер обмена
  1. $file = 'file232';
  2. $baseFile = substr($file, 0, -2);


проблема то в чем?
5. TurnOff - 16 Июля, 2014 - 14:12:48 - перейти к сообщению
Panoptik пишет:
а что можно трогать?
(Добавление)
допустим оригинальный файл можно узнать так

PHP:
скопировать код в буфер обмена
  1. $file = 'file232';
  2. $baseFile = substr($file, 0, -2);


проблема то в чем?


Так не покатит )))) Тут как я понял надо 2 массива делать и проверять, где первоначальное название, а где уже дублируется...
6. Sail - 16 Июля, 2014 - 14:47:51 - перейти к сообщению
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM `qwerty` WHERE convert(reverse(`image`), decimal) = 0;

Этот запрос вернёт строки с "первоначальными" именами файлов из таблицы (докустим, qwerty).
Если, конечно, "первоначальное" имя однозначно не заканчивается цифирью Улыбка
Ну а дальше - like "первоначальное_имя%" в помощь.
7. TurnOff - 16 Июля, 2014 - 14:50:43 - перейти к сообщению
Sail пишет:
CODE (SQL):
скопировать код в буфер обмена
  1. SELECT * FROM `qwerty` WHERE convert(reverse(`image`), decimal) = 0;

Этот запрос вернёт строки с "первоначальными" именами файлов из таблицы (докустим, qwerty).
Если, конечно, "первоначальное" имя однозначно не заканчивается цифирью Улыбка
Ну а дальше - like "первоначальное_имя%" в помощь.

а вот косяк, файл может уже цифрой заканчиваться )))
8. Panoptik - 16 Июля, 2014 - 16:38:58 - перейти к сообщению
вы сперва внятно объясните что и как вы делаете (должны сделать) на словах без кода
если устно вы сможете это сделать, значит программно без проблем задача решается

если вы не сможете объяснить что и как, то увы ванга и настрадамус в отпуске
9. TurnOff - 16 Июля, 2014 - 17:58:45 - перейти к сообщению
Panoptik пишет:
вы сперва внятно объясните что и как вы делаете (должны сделать) на словах без кода
если устно вы сможете это сделать, значит программно без проблем задача решается

если вы не сможете объяснить что и как, то увы ванга и настрадамус в отпуске

Объясняю ещё раз. Есть файлы в папке, в них располагаются данные. Вся информация хранится в БД. То есть какое-то веб приложение считывает данные с бд и потом сохраняет в файлы. Мне нужно сделать своё веб-приложение, которое показывает первоначальное наименование файла и его дубликаты. Дубликаты я уже писал как создаются.

 

Powered by ExBB FM 1.0 RC1