Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.94/18: Рейтинг темы: голосов - 18, средняя оценка - 4.94
0 / 0 / 0
Регистрация: 15.08.2015
Сообщений: 8

Telegram Bot api удаление данных БД inline клавиатурой

26.01.2018, 22:21. Показов 5329. Ответов 4

Студворк — интернет-сервис помощи студентам
Подскажите, пожалуйста, как реализовать удаление из базы данных вопроса.
1.callback_data кнопки формируется динамически на основании id таблицы базы данных 'quest_'.$queid
2. В зависимости от callback_data из базы данных должна удалиться определенная запись соответствующая id таблицы.

$query = "SELECT * FROM quest WHERE questfromuid='$unicid'";
$result = $dbc->query($query);
if (!$result) die ($dbc->error);
$rows = $result->num_rows;
for ($j=0; $j<$rows; $j++){
$result->data_seek($j);
$row = $result->fetch_array (MYSQLI_ASSOC);
$queid=$row['qid'];
$qth=$row['qtheme'];
$que=$row['question'];

$btnqdell = array ("text"=>'Удалить', "callback_data"=>'quest_'.$queid);
$inline_keyboard = [[$btnqdell]];
$keyboard=array("inline_keyboard"=>$inli ne_keyboard);
$replyMarkup = json_encode($keyboard);
$data=$btnqdell['callback_data'];
$message="<b>Tема: </b>$qth \n<b>Вопрос: </b>$que будет удален!";
file_get_contents(API."/sendMessage?chat=$unicid&text=".urlencod e($message)."&reply=$replyMarkup");
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.01.2018, 22:21
Ответы с готовыми решениями:

Как создать inline кнопки?
При создании бота столкнулся с одной, не очень приятной, проблемой. Связанна она с созданием inline кнопок. В более ранних версиях...

Api Telegram Bot
Захотелось попробовать написать бота для телеграмм. Решил писать без библиотек, просто запросы. Однако когда захотел вставить Inline...

Парсер + Telegram-bot-api
Здравствуйте, форумчане! Вообщем есть парсер needle.get(url, function(err, res){ if(err) throw err; var $ =...

4
0 / 0 / 0
Регистрация: 15.08.2015
Сообщений: 8
28.01.2018, 17:55  [ТС]
Есть у кого какие-либо соображения?
0
 Аватар для dukesov
19 / 18 / 11
Регистрация: 24.08.2015
Сообщений: 471
03.02.2018, 21:00
Цитата Сообщение от Marat7777777 Посмотреть сообщение
В зависимости от callback_data из базы данных должна удалиться определенная запись соответствующая id таблицы.
PHP
1
2
3
4
5
6
7
8
9
$data = $btnqdell['callback_query']['data']; //$btnqdell или от куда у Вас берется ответ $btnqdell = json_decode(file_get_contents('php://input'), true);
$query = "DELETE FROM `таблица` WHERE `строка` = '$data'"; //Удаляем из базы данных
$message = "Удалено";
file_get_contents(API."/sendMessage?chat_id=".$unicid."&text=".urlencode($message));
 
$chat_id = $obj['callback_query']['message']['chat']['id'];
$message_id = $obj['callback_query']['message']['message_id'];
file_get_contents(API."/editMessageReplyMarkup?chat_id=".$chat_id."&message_id=".$message_id); //Удаляем кнопки после их нажатия
exit();
0
0 / 0 / 0
Регистрация: 15.08.2015
Сообщений: 8
04.02.2018, 21:55  [ТС]
dukesov, Все верно. Вы описываете принцип удаления из БД, но это не то. У вас получается, что при любом значении $data будет формироваться запрос к БД.
Мне же необходимо условие: if ($data=== 'quest_'.$queid){
//Удаляем из базы данных
}
Вот этого условия никак не получается добиться
0
 Аватар для dukesov
19 / 18 / 11
Регистрация: 24.08.2015
Сообщений: 471
05.02.2018, 12:41
Marat7777777, сколько у Вас таблиц? Напишите их структуру. Опишите что Вы хотите сделать, с какой таблицы берется $queid, с какой надо удалить, ничего не понял что Вы хотите.
Условие можно сделать такое:
PHP
1
2
3
4
5
if(isset($btnqdell['callback_query'])){
    $data = $btnqdell['callback_query']['data'];
    ... //Удаление записи, удаление кнопок и т.д.;
    exit();
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.02.2018, 12:41
Помогаю со студенческими работами здесь

Бот telegram не может подключиться к https://api.telegram.org:443: (Java)
Здравствуйте! Возникла такая проблема при запуске бота в intelij idea ultimate программа выдает такое сообщение:&quot;юн. 02, 2018 8:42:11...

Как сделать кнопки?
Подскажите как реализвать кнопки в телеграм боте, без либов подобных telebot

Telegram Bot
Пытался сделать телеграм бота через модули, как описано здесь https://metanit.com/sharp/mvc5/19.8.php Когда заливаю проект на хостинг,...

Telegram bot
Хочу написать бота для телеграмма, чтобы оповещал о приходе сообщений от определенного отправителя. Хотела просто уточнить несколько...

Как сделать игру многопользовательской?
from telegram.ext import Updater, CommandHandler, MessageHandler import logging,random, sys from telegram import Message, Update,Bot,...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка. Рецензия / Мнение Это мой обзор планшета X220 с точки зрения школьника. Недавно я решила попытаться уменьшить свой. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru