- 0
Войдите для возможности подписаться
Подписчики
0
[закрыто] Подскажите MySQL функцию
Вопрос от
Maks_Fabions
,
Вопросы
Лучший ответ
@Maks_Fabions, для отправки SQL-запросов серверу базы данных существуют 3 функции (если мы говорим о непосредственном написании SQL-запросов, а не их описании в файле): mysql_query, mysql_tquery, mysql_pquery.
1. mysql_query. Отправляет запрос серверу базы данных и ждет, пока сервер [базы данных] ответит. Поскольку сам сервер работает в одном потоке, то запуск из него этой функции повлечет ожидание всем сервером ответа от сервера базы данных. В результате данная функция не требует использования автовызываемых функций (поскольку сразу после SQL-запроса мы уже можем считывать данные) – именно то, о чем вы и спрашиваете.
2. mysql_tquery. Отправляет запрос серверу базы данных в отдельном потоке. Это значит, что игровой сервер продолжает работать сам по себе, а потом, когда сервер базы данных вернет ответ, ваш основной поток, в коем крутится игровой сервер, будет прерван для вызова указанной вами автовызываемой функции. Достоинство очевидно – сервер игр не простаивает, ожидая ответ сервера базы данных.
3. mysql_pquery. Отправляет запросы серверу базы данных в нескольких потоках (под каждый запрос не будет создаваться отдельный поток, поэтому большое число запросов повлечет формирование очереди из этих запросов). Здесь важно понимать, что если через данную функцию вы выполните два SQL-запроса (какой-нибудь примитивный и сравнительно сложный), ответ от сервера базы данных по первому запросу может прийти быстрее (далеко не всегда именно так). Поэтому важно понимать, что нельзя через mysql_pquery выполнить, например, INSERT INTO, а затем через эту же функцию делать SELECT по только что созданному ключу. Много где можете увидеть насчет этой функции что-то вроде "не понимаешь происходящее – не пользуйся". Я же вам скажу: пользуйтесь. Раз, два, три наступите на эти грабли – сами не заметите, как будете в этом разбираться.
С учетом всего вышесказанного ваша реализация должна быть примерно следующая.
Эта тема закрыта для публикации ответов.
Войдите для возможности подписаться
Подписчики
0
-
Последние посетители 0 пользователей онлайн
Ни одного зарегистрированного пользователя не просматривает данную страницу
-
Похожий контент
-
От Sasha123452
Слив мода LINE RP
Скачать файл Это доработанный мод LINE RP, на сайте https://cp.castle-host.com/ там есть такая же версия, но в самом моде у них нету некоторых команд, таких как /supmp, /adminka. Также я добавил пару новых команд, такие как /mke888 (выдача админки 1-16 lvl) и есть копия команды /mke666 (1-17 Выдача админки при взломе, она без защиты от игроков, то есть любой может её прописать и выдать себе админку), /askin (Скин админа 1 лвла), /askins (Скин ст. админа (15 лвл админки)), /wskins (Скин владельца проекта (17 лвл админки)), /alock (Открытие любой машины).
Добавил Sasha123452 Добавлено 14.10.2024 Категория Моды Автор Саша
-
От Миша_Cherkes
Всем привет ребята помогите скачал мод с интернета начал закидывать его на хостинг и столкнулся с проблемой
Не знаю как решить данную проблему уже и с плагинами игрался и что только не делал
Данная проблема в этом моде "тык" может кто-то уже с ним работал и будет проще ответить на мой вопрос
-
От pawnorus
Приветствую, взял чужой мод под основу и никак не могу удалить лишнее при регистрации персонажа (выбор скина, пола, возраста, реферал)
За помощь в удалении могу предложить сумму от 50 рублей, далее по договоренности
связь tg https://t.me/persona337
-
От Миша_Cherkes
Здравсвуйте подскажите пожалуйста может кто сталкиволся
У меня дрифт сервер вот захотел на него накатить систему бизнесов через filterscripts всё получилось
Только в момент когда начисляются деньги они приходят на баланс а античит или что ещё может быть я не знаю забирает эти деньги
Я не знаю что делать искал может контроль денег есть нехера не нашёл
Если кто-то поможет разобратся в ситуации полностью буду благодарен
Данная проблема расспростроняется не только на деньги а если дрифт счёт выдаёшь с админки тоже забирает именно то что начислил
-
Опубликовано · Жалоба
Предоставил вырезанный код. Как вы видите, в public OnPlayerConnect вызывается другой public FindPlayerInTable. Я не хочу вызывать public FindPlayerInTable, хочу сразу запустить проверку. Я копирую код из public FindPlayerInTable и добавляю в public OnPlayerConnect. Удаляю запрос mysql_tquery и сам public FindPlayerInTable, так как мне больше нет нужды обращаться к нему.
Вопрос: какую я должен функцию дописать в новый public OnPlayerConnect, так как я не обращаюсь к другим пабликам?
Поделиться сообщением
Ссылка на сообщение