Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
2 / 2 / 3
Регистрация: 17.12.2014
Сообщений: 43

Нужно проверить существует ли такая же запись и если да то обновить ее

10.07.2015, 11:33. Показов 865. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток!
Есть БД с записями, к примеру с курсом валют, мы подтягиваем новые данные с какого то сайта забиваем их в массив. Потом нам нужно проверить существует ли такая запись к примеру:
USD 21,2
EUR 23,5
RUB 32,4
Если USD существует то рядом добавить новую колонку и в ней должно храниться курс на момент подтягивания и т.д..
Должно получиться так:
USD 21,2 21,5
EUR 23,5 23,6
RUB 0,32 0,33
И так каждый раз когда подтягиваются данные. Если к примеру подтянуло еще валюту которой нету в БД, то ее не добавлять.
Какой то примерчик может кто то подкинуть может, или подсказать в каком направлении копать?

Добавлено через 21 минуту
Написал вот такой вот код но добавляет только последний элемент массива не зависимо от того есть такой в базе или нету.
PHP
1
2
3
4
5
6
7
8
9
    foreach($html->find('tr') as $article) {
        $valuta = $article->find('td', 0)->plaintext;
        $kurs = $article->find('td', 1)->plaintext;
        $query = "SELECT * FROM tab WHERE valuta='$valuta'";
        if($query==NULL){echo "Такой записи нету!";}
    else{$qery  = mysql_query("ALTER TABLE  `tab` ADD  `kurs2` VARCHAR( 120 ) NOT NULL ");
    $query = mysql_query("UPDATE tab SET kurs2='$kurs'");
           }
    }
Добавлено через 18 часов 29 минут
Переписал немного код
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
function db_connect(){
    define('DB_HOST', 'localhost');
    define('DB_USER', 'root');
    define('DB_PSWD', '');
    define('DB_NAME', 'test');
 
     $connection = mysql_connect(DB_HOST, DB_USER, DB_PSWD);
     mysql_query("SET NAMES utf8");
     if(!$connection || !mysql_select_db(DB_NAME, $connection))
     {
         return false;
     }
     return $connection;
}
function db_result_to_array($result)
     {
         $res_array = array();
         $count = 0;
         while($row = mysql_fetch_array($result))
         {
             $res_array[$count] = $row;
             $count++;
         }
         return $res_array;
     }
     db_connect();
    
    function sqllike($zapros){
    db_connect();
    $query = "SELECT kod FROM tab WHERE kod='$zapros'";
    $result = mysql_query($query);
    $result = db_result_to_array($result);
    return $result;
    }
    
    $mas = [213,114,218,112,203];
    foreach ($mas as $key => $value) {
    $kod = sqllike($value);
    foreach ($kod as $key2 => $kodbd) {
        echo $koddb['kod'].' - код из БД<br>';
        if($koddb['kod']!=$value){$qery = mysql_query("ALTER TABLE  `tab` ADD  `kurs2` VARCHAR( 120 ) NOT NULL ");
    $query = mysql_query("UPDATE tab SET kurs2='$value'");
        }
    else{echo "Такой записи нету - ".$value."<br>";}
        }
    }
Теперь проверяет наличие но обновляет все записи, и подставляет последний элемент массива, здесь без подтягиваний с другого сайта просто эксперементирую с массивом суть не меняется. В БД есть 111, 112, 113, 114, 115, 116. Оно видит что 114 и 112 подходит но не отображает их в этом месте
PHP
1
echo $koddb['kod'].' - код из БД<br>';
В базе добавляет новую колонку но забивает ее полностью последним совпавшим элементом тоисть 112.

Добавлено через 5 минут
Подскажите как прописать что б обновляло конкретную запись.

Добавлено через 16 минут
Решил задачу следующим образом:
PHP
1
2
3
4
5
6
7
8
9
10
11
$mas = [213,114,218,112,203];
    foreach ($mas as $key => $value) {
    $kod = sqllike($value);
    foreach ($kod as $key2 => $kodbd) {
        echo $koddb['kod'].' - код из БД<br>';
        if($koddb['kod']!=$value){$qery = mysql_query("ALTER TABLE  `tab` ADD  `kurs2` VARCHAR( 120 ) NOT NULL ");
    $query = mysql_query("UPDATE tab SET kurs2='$value' WHERE kod='$value'");
        }
    else{echo "Такой записи нету - ".$value."<br>";}
        }
    }
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.07.2015, 11:33
Ответы с готовыми решениями:

Не создавать запись в БД если она уже существует а просто обновить
Доброго всем дня. Ситуация такая, есть БД MSSQL и php скрипт добавления данных Задача в следующем, как реализовать так чтобы, если...

Нужно проверить существует ли определенный объект, и после этого выполнить действие, если он есть
Доброе время суток! Возникла у меня потребность проверить существует ли объект определенный и после этого выполнить действие если он...

Если запись в столбце существует, то ничего не делать, если запись отсутствует, то записать нужное значение. Как реализовать?
Если запись в столбце существует, то ничего не делать, если запись отсутствует, то записать нужное значение. Как реализовать?

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.07.2015, 11:33
Помогаю со студенческими работами здесь

Как открыть файл на чтение и запись, создав его, если его не существует, и перезаписать, если он существует?
Как открыть файл на чтение и запись, создав его, если его не существует, и перезаписать, если он существует?

Проверить, существует ли каталог, и если не существует - создать
Как средствами VB6 проверить существует ли каталог, и если не существует - создать? DName$ = &quot;C:\111&quot; If Dir(DName$) &lt;&gt;...

Запретить запись в базу, если в базе уже есть такая запись - PHP БД
Люди добрые помогите кто чем сможет. Есть запрос $number = $_POST; $datetime = $_POST; $dept = $_POST; $text = $_POST; $disp...

Процедура с условием: если такая запись есть, то update, если нет, то insert
Хочу сделать процедуру по вбиванию/удалению. Если такая запись есть, то update, если нет, то insert. Подсказали примерно такую штуку, но...

Если строка существует - обновить, иначе - вставить новую
Здравствуйте! Подскажите, как сделать в MSSQL запрос, который работал бы по такой логике: &quot;если строка существует - обновить, иначе -...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru