Вопросы

trevison
Активный

столкнулся с несколькими проблемами при переводе на новую версию MySQL

по каким-то причинам вылезают варнинги на mysql_query, хотя вроде и не должно и не знаю как можно заменить функции ниже

f(query, "INSERT INTO `players` (`pNick`, `pPassword`, `pRegip`, `pDatareg`) VALUES ('%s', '%s', '%s', '%s')", sqlname, sqlpass,myIP,cdate);
mysql_query(MySQLGo, query); // warning 213: tag mismatch
stock GetAccountID(playerid)
{
    new query[128];
    f(query,"SELECT `pID` FROM `players` WHERE `pNick` = '%s'", sendername(playerid));
    mysql_query(MySQLGo, query); // warning 213: tag mismatch
    mysql_store_result(); // error 017: undefined symbol "mysql_store_result"
    if(mysql_num_rows() == 1)
    {
        PlayerInfo[playerid][pID] = mysql_fetch_int(); // error 017: undefined symbol "mysql_fetch_int"
        mysql_free_result();  // error 017: undefined symbol "mysql_free_result"
        return PlayerInfo[playerid][pID];
    }
    return false;
}

подключение к бд выглядит так:

MySQLGo = mysql_connect(mysql_host, mysql_user, mysql_database, mysql_password);
mysql_tquery(MySQLGo,"set character_set_client='cp1251'");
mysql_tquery(MySQLGo,"set character_set_results='cp1251'");
mysql_tquery(MySQLGo,"set collation_connection='cp1251_general_ci'");
if(mysql_errno() == 0)  printf("Подключение к базе выполнено. Кодировка настроена...\n\n");
else printf("К базе подключиться не удалось. Проверьте логин/пароль и связь с интернетом.\n\n");

 

Отредактировано пользователем trevison

Поделиться сообщением


Ссылка на сообщение

1 ответ на этот вопрос

  • 0
Sleash
Завсегдатый

Итак, во-первых переменная MySQLGo у Вас должна быть объявлена так:

new MySQL:MySQLGo;

Об этом можно узнать, если посмотреть требуемы параметры mysql_query или тип переменной, которую должна вернуть mysql_connect

// mysql_query требует епременную с типом MySQL
native Cache:mysql_query(MySQL:handle, const query[], bool:use_cache = true);
// а mysql_connect возвращает переменную с типом MySQL
native MySQL:mysql_connect(const host[], const user[], const password[], const database[], MySQLOpt:option_id = MySQLOpt:0);

// И да, компилятору (Слово удалено системой), что mysql_connect тупо возвращает число с тегом MySQL
// Зато mysql_query можно юзать так:
mysql_query(1const query[]);

Во вторых, попробуйте GetAccountID использовать вот так:

  открыть спойлер

 

Отредактировано пользователем Sleash

Поделиться сообщением


Ссылка на сообщение
Гость
Эта тема закрыта для публикации ответов.
  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Похожий контент

    • Владислав Малиновский
      От Владислав Малиновский
      SWEEK RUSSIA — онлайн игра на телефон с открытым миром, в котором Вы можете создать персонажей вместе со своими друзьями и начать весело проводить время. Вы можете продвигаться по сюжету квестовых миссий или же начать игру с зарабатывания денег в транспортной компании. Создавать организации, подниматься по карьерной лестнице. Заполучив влияние над другими игроками - попробуй себя в роли Президента.
       
      Нам нужны ответственные люди на должность главного администратора. Если вы считаете себя адекватным и ответственным, отпишите в vk.com/devmaksim или t.me/raphmarci.
       
      Официальный сайт проекта - sweekrussia.ru
      Официальный форум проекта - forum.sweekrussia.ru
      Официальное сообщество VK - vk.com/sweekrussia.game
      Официальный TG канал - t.me/sweek_dev
    • bogdan295@gmai
      От bogdan295@gmai
      Здраствуйте, я создавал новую организации когда дело дашло до пикапов они не создаются 
      new lssd1; new lssd2;  else if(pickupid == lssd2)// Вход     {         SetPlayerInteriorEx(playerid,0);         SetPPos(playerid,1567.5510,-1657.9956,5.3859);         SetPlayerFacingAngle(playerid, 500);         return true;     } else if(pickupid == lssd1)// Вsход     {         SetPlayerInteriorEx(playerid,0);         SetPPos(playerid,630.0542,-572.0032,16.3359);         SetPlayerFacingAngle(playerid, 500);         return true;     }     lssd2 = CreatePickupAC(1318,1,626.9653,-571.8394,17.9207, 147); // вход лссд     lssd1 = CreatePickupAC(1318,1,1567.4720,-1660.6494,5.3859, 147); // выход лссд Что я сделал не так?