Премини към съдържанието
Форумът в приложение

По-лесно сърфиране. Научи повече.

Kaldata.com - Форуми

Приложение на форума на цял екран с push известия, значки и други.

За да инсталирате това приложение на iOS и iPadOS
  1. Докоснете Иконата за споделяне в Safari
  2. Превъртете менюто и докоснете Добавяне към началния екран.
  3. Докоснете Добавяне в горния десен ъгъл.
За да инсталирате това приложение на Android
  1. Докоснете менюто с 3 точки (⋮) в горния десен ъгъл на браузъра.
  2. Докоснете Добавяне към началния екран или Инсталиране на приложение.
  3. Потвърдете, като докоснете Инсталиране.

Добре дошли!

Добре дошли в нашите форуми, пълни с полезна информация. Имате проблем с компютъра или телефона си? Публикувайте нова тема и ще намерите решение на всичките си проблеми. Общувайте свободно и открийте безброй нови приятели.

Моля, регистрирайте се за да публикувате тема и да получите пълен достъп до всички функции.

 

Коригиране на релационна таблица?

Featured Replies

Здравейте,

Имам проблем, с който се мъча от много време - Имам 2 таблици с данни, като за връзка между двете използвам релационна таблица, съдържаща просто уникалните ключове на закачените записи.

Пример: таблица 1 съдържа новини /row_id/, таблица 2 съдържа тагове /tag_id/ и релационната таблица съдържа в себе си записи за всеки закачен таг към всяка публикация.

Да, но при редактиране на публикация искам например да сменя таговете - как обаче да сравня и заменя (изтрия и добавя) разликите? Пробвах следния начин, но не сработва винаги:

<?php
    $old_selection = array( ... );
    $new_selection = array( ... );

    if ($old_selection != $new_selection) {
        $to_delete = array_diff($old_selection, $new_selection);
        if (!empty($to_delete)) {
            foreach ($to_delete as $del) {
                mysqli_query($conn, "DELETE FROM table_rel WHERE row_id = row_id AND tag_id = $del");   
            }
        }
        $to_add = array_diff($new_selection, $old_selection);
        if (!empty($to_add)) {
            foreach ($to_add as $add) {
                mysqli_query($conn, "INSERT INTO table_rel (tag_id, row_id) VALUES ($add, row_id)");   
            }
        }
    }
?>

Някакви предложения да имате? :/

Редактирано от streleca_stz (преглед на промените)

Такива неща се правят, като просто изтриваш всички стари записи и записваш всичко наново.

$row_id = ... // това трябва да е id-to на реда
mysqli_query("DELETE FROM table_rel WHERE row_id = $row_id");
foreach ($new_selection as $tag_id) {
	mysqli_query("INSERT INTO table_rel(tag_id, row_id) VALUES($tag_id, $row_id)");
}

 

  • Автор
преди 12 минути, plamenbm86 написа:

Такива неща се правят, като просто изтриваш всички стари записи и записваш всичко наново.


$row_id = ... // това трябва да е id-to на реда
mysqli_query("DELETE FROM table_rel WHERE row_id = $row_id");
foreach ($new_selection as $tag_id) {
	mysqli_query("INSERT INTO table_rel(tag_id, row_id) VALUES($tag_id, $row_id)");
}

 

Всъщност този метод ми е до болка познат, но въпреки всичко исках да разбера дали има друг начин, понеже искам максимално да "олекотя" конекциите до базата с данни...

Няма какво да се олекотяват. Определено еднo DELETE e по-добре и по-бързо от няколко. Колкото е по-малък броя на извикване на mysqli_query толкова по-добре.

А горният код е малко или много безмислен. DELETE заявките изтриват таговете за всички row_id редове защото row_id = row_id e винаги вярно. Тия INSERT заявки 100% дават грешка защото имаш някакво row_id във VALUES, което трябва да е реaлна стойност, а не име.

Впрочем, ако искаш малко повече оптимизация, записването може да се направи с INSERT на множество от редове. Става като след VALUES се въведат много редове разделени със запетая. Потърси в интернет за точния синтаксис, ако не съм обяснил достатъчно ясно.

Редактирано от plamenbm86 (преглед на промените)

Разгледай какво е foreign key cascade

Архивирана тема

Темата е твърде стара и е архивирана. Не можете да добавяте нови отговори в нея, но винаги можете да публикувате нова тема, в която да продължи дискусията. Регистрирайте се или влезте във вашия профил за да публикувате нова тема.

Разглеждащи това в момента 0

  • Няма регистрирани потребители разглеждащи тази страница.

Дарение

  • Подкрепи съществуването на форума - направи дарение
    26%
    Дарени 256.00 EUR от нужните 1,000.00 EUR

Бюлетин

Получавайте известие, когато има важна промяна или новина свързана с форума.

Профил

Навигация

Търсене

Търсене

Конфигуриране на push известия в браузъра

Chrome (Android)
  1. Докоснете иконата на катинар до адресната лента.
  2. Докоснете Разрешения → Известия.
  3. Променете предпочитанията си.
Chrome (Desktop)
  1. Кликнете върху иконата на катинар в адресната лента.
  2. Изберете Настройки на сайта.
  3. Намерете Известия и коригирайте предпочитанията си.