public OnPlayerLogin(playerid,password[]) { MySQLCheckConnection(); new tmp2[256]; new string2[64]; new playername2[MAX_PLAYER_NAME]; new playernamesplit[3][MAX_PLAYER_NAME]; GetPlayerName(playerid, playername2, sizeof(playername2)); split(playername2, playernamesplit, '_'); MySQLFetchAcctSingle(PlayerInfo[playerid][pSQLID], "Password", PlayerInfo[playerid][pKey]); if(strcmp(PlayerInfo[playerid][pKey],password, true ) == 0 ) { new Data[1024]; new Field[64]; MySQLFetchAcctRecord(PlayerInfo[playerid][pSQLID], Data); //new idx; //new Fields = mysql_field_count(); for(new rcnt = 1; mysql_fetch_field(rcnt, Field); rcnt++) { // The rcnt values here represent the order of the columns in the characters table, so don't mess with them // If you add a column to the table, just add a new line with a +1 rcnt to the block below // Start it at 3 to skip the first few records we don't need (id, player name, password) if (rcnt == 3) PlayerInfo[playerid][pLevel] = strval(Field); if (rcnt == 4) PlayerInfo[playerid][pAdmin] = strval(Field); if (rcnt == 5) PlayerInfo[playerid][pDonateRank] = strval(Field); if (rcnt == 6) PlayerInfo[playerid][gPupgrade] = strval(Field); if (rcnt == 7) PlayerInfo[playerid][pConnectTime] = strval(Field); if (rcnt == 8) PlayerInfo[playerid][pReg] = strval(Field); if (rcnt == 9) PlayerInfo[playerid][pSex] = strval(Field); if (rcnt == 10) PlayerInfo[playerid][pAge] = strval(Field); if (rcnt == 11) PlayerInfo[playerid][pOrigin] = strval(Field); if (rcnt == 12) PlayerInfo[playerid][pCK] = strval(Field); if (rcnt == 13) PlayerInfo[playerid][pMuted] = strval(Field); if (rcnt == 14) PlayerInfo[playerid][pExp] = strval(Field); if (rcnt == 15) PlayerInfo[playerid][pCash] = strval(Field); if (rcnt == 16) PlayerInfo[playerid][pAccount] = strval(Field); if (rcnt == 17) PlayerInfo[playerid][pCrimes] = strval(Field); if (rcnt == 18) PlayerInfo[playerid][pKills] = strval(Field); if (rcnt == 19) PlayerInfo[playerid][pDeaths] = strval(Field); if (rcnt == 20) PlayerInfo[playerid][pArrested] = strval(Field); if (rcnt == 21) PlayerInfo[playerid][pWantedDeaths] = strval(Field); if (rcnt == 22) PlayerInfo[playerid][pPhoneBook] = strval(Field); if (rcnt == 23) PlayerInfo[playerid][pLottoNr] = strval(Field); if (rcnt == 24) PlayerInfo[playerid][pFishes] = strval(Field); if (rcnt == 25) PlayerInfo[playerid][pBiggestFish] = strval(Field); if (rcnt == 26) PlayerInfo[playerid][pJob] = strval(Field); if (rcnt == 27) PlayerInfo[playerid][pPayCheck] = strval(Field); if (rcnt == 28) PlayerInfo[playerid][pHeadValue] = strval(Field); if (rcnt == 29) PlayerInfo[playerid][pJailed] = strval(Field); if (rcnt == 30) PlayerInfo[playerid][pJailTime] = strval(Field); if (rcnt == 31) PlayerInfo[playerid][pMats] = strval(Field); if (rcnt == 32) PlayerInfo[playerid][pDrugs] = strval(Field); if (rcnt == 33) PlayerInfo[playerid][pLeader] = strval(Field); if (rcnt == 34) PlayerInfo[playerid][pMember] = strval(Field); if (rcnt == 35) PlayerInfo[playerid][pFMember] = strval(Field); if (rcnt == 36) PlayerInfo[playerid][pRank] = strval(Field); if (rcnt == 37) PlayerInfo[playerid][pChar] = strval(Field); if (rcnt == 38) PlayerInfo[playerid][pContractTime] = strval(Field); if (rcnt == 39) PlayerInfo[playerid][pDetSkill] = strval(Field); if (rcnt == 40) PlayerInfo[playerid][pSexSkill] = strval(Field); if (rcnt == 41) PlayerInfo[playerid][pBoxSkill] = strval(Field); if (rcnt == 42) PlayerInfo[playerid][pLawSkill] = strval(Field); if (rcnt == 43) PlayerInfo[playerid][pMechSkill] = strval(Field); if (rcnt == 44) PlayerInfo[playerid][pJackSkill] = strval(Field); if (rcnt == 45) PlayerInfo[playerid][pCarSkill] = strval(Field); if (rcnt == 46) PlayerInfo[playerid][pNewsSkill] = strval(Field); if (rcnt == 47) PlayerInfo[playerid][pDrugsSkill] = strval(Field); if (rcnt == 48) PlayerInfo[playerid][pCookSkill] = strval(Field); if (rcnt == 49) PlayerInfo[playerid][pFishSkill] = strval(Field); if (rcnt == 50) PlayerInfo[playerid][pSHealth] = floatstr(Field); if (rcnt == 51) PlayerInfo[playerid][pHealth] = floatstr(Field); if (rcnt == 52) PlayerInfo[playerid][pInt] = strval(Field); if (rcnt == 53) PlayerInfo[playerid][pLocal] = strval(Field); if (rcnt == 54) PlayerInfo[playerid][pTeam] = strval(Field); if (rcnt == 55) PlayerInfo[playerid][pModel] = strval(Field); if (rcnt == 56) PlayerInfo[playerid][pPnumber] = strval(Field); if (rcnt == 57) PlayerInfo[playerid][pPhousekey] = strval(Field); if (rcnt == 58) PlayerInfo[playerid][pPcarkey] = strval(Field); if (rcnt == 59) PlayerInfo[playerid][pPbiskey] = strval(Field); if (rcnt == 60) PlayerInfo[playerid][pPos_x] = floatstr(Field); if (rcnt == 61) PlayerInfo[playerid][pPos_y] = floatstr(Field); if (rcnt == 62) PlayerInfo[playerid][pPos_z] = floatstr(Field); if (rcnt == 63) PlayerInfo[playerid][pCarLic] = strval(Field); if (rcnt == 64) PlayerInfo[playerid][pFlyLic] = strval(Field); if (rcnt == 65) PlayerInfo[playerid][pBoatLic] = strval(Field); if (rcnt == 66) PlayerInfo[playerid][pFishLic] = strval(Field); if (rcnt == 67) PlayerInfo[playerid][pGunLic] = strval(Field); if (rcnt == 68) PlayerInfo[playerid][pGun1] = strval(Field); if (rcnt == 69) PlayerInfo[playerid][pGun2] = strval(Field); if (rcnt == 70) PlayerInfo[playerid][pGun3] = strval(Field); if (rcnt == 71) PlayerInfo[playerid][pGun4] = strval(Field); if (rcnt == 72) PlayerInfo[playerid][pAmmo1] = strval(Field); if (rcnt == 73) PlayerInfo[playerid][pAmmo2] = strval(Field); if (rcnt == 74) PlayerInfo[playerid][pAmmo3] = strval(Field); if (rcnt == 75) PlayerInfo[playerid][pAmmo4] = strval(Field); if (rcnt == 76) PlayerInfo[playerid][pCarTime] = strval(Field); if (rcnt == 77) PlayerInfo[playerid][pPayDay] = strval(Field); if (rcnt == 78) PlayerInfo[playerid][pPayDayHad] = strval(Field); if (rcnt == 79) PlayerInfo[playerid][pCDPlayer] = strval(Field); if (rcnt == 80) PlayerInfo[playerid][pWins] = strval(Field); if (rcnt == 81) PlayerInfo[playerid][pLoses] = strval(Field); if (rcnt == 82) PlayerInfo[playerid][pAlcoholPerk] = strval(Field); if (rcnt == 83) PlayerInfo[playerid][pDrugPerk] = strval(Field); if (rcnt == 84) PlayerInfo[playerid][pMiserPerk] = strval(Field); if (rcnt == 85) PlayerInfo[playerid][pPainPerk] = strval(Field); if (rcnt == 86) PlayerInfo[playerid][pTraderPerk] = strval(Field); if (rcnt == 87) PlayerInfo[playerid][pTut] = strval(Field); if (rcnt == 88) PlayerInfo[playerid][pMissionNr] = strval(Field); if (rcnt == 89) PlayerInfo[playerid][pWarns] = strval(Field); if (rcnt == 90) PlayerInfo[playerid][pAdjustable] = strval(Field); if (rcnt == 91) PlayerInfo[playerid][pFuel] = strval(Field); if (rcnt == 92) PlayerInfo[playerid][pMarried] = strval(Field); if (rcnt == 93) PlayerInfo[playerid][pMarriedTo] = strmid(PlayerInfo[playerid][pMarriedTo], Field, 0, strlen(Field)-1, 255); if (rcnt == 94) PlayerInfo[playerid][pLocked] = strval(Field); if (rcnt == 95) PlayerInfo[playerid][pLinked] = strval(Field); if (rcnt == 96) PlayerInfo[playerid][pCrashed] = strval(Field); if (rcnt == 97) PlayerInfo[playerid][pToitumus] = strval(Field); if (rcnt == 98) PlayerInfo[playerid][pPcarkey2] = strval(Field); if (rcnt == 99) PlayerInfo[playerid][pPcarkey3] = strval(Field); if (rcnt == 100) PlayerInfo[playerid][pEaglep] = strval(Field); if (rcnt == 101) PlayerInfo[playerid][pSDpistolp] = strval(Field); if (rcnt == 102) PlayerInfo[playerid][pMP5p] = strval(Field); if (rcnt == 103) PlayerInfo[playerid][pShotgunp] = strval(Field); if (rcnt == 104) PlayerInfo[playerid][pAk47p] = strval(Field); if (rcnt == 105) PlayerInfo[playerid][pM4p] = strval(Field); if (rcnt == 106) PlayerInfo[playerid][pRiflep] = strval(Field); } //mysql_free_result(); } else { SendClientMessage(playerid, COLOR_WHITE, "SERVER: Vale parool !"); gPlayerLogTries[playerid] += 1; if(gPlayerLogTries[playerid] == 4) { PlayerInfo[playerid][pLocked] = 1; } return 1; } PlayerInfo[playerid][pAdjustable] = 0; ResetPlayerMoney(playerid); ConsumingMoney[playerid] = 1; SafeGivePlayerMoney(playerid,PlayerInfo[playerid][pCash]); CurrentMoney[playerid] = PlayerInfo[playerid][pCash]; if(PlayerInfo[playerid][pReg] == 0) { PlayerInfo[playerid][pLevel] = 1; PlayerInfo[playerid][pSHealth] = 0.0; PlayerInfo[playerid][pHealth] = 50.0; PlayerInfo[playerid][pPos_x] = 1612.3240; PlayerInfo[playerid][pPos_y] = -2330.1670; PlayerInfo[playerid][pPos_z] = 13.5469; PlayerInfo[playerid][pInt] = 15; PlayerInfo[playerid][pLocal] = 255; PlayerInfo[playerid][pTeam] = 3; PlayerInfo[playerid][pModel] = 26; new randphone = 100000 + random(899999);//minimum 1000 max 9999 //giving one at the start PlayerInfo[playerid][pPnumber] = randphone; PlayerInfo[playerid][pPhousekey] = 255; PlayerInfo[playerid][pPbiskey] = 255; PlayerInfo[playerid][pPcarkey] = 999; PlayerInfo[playerid][pPcarkey2] = 999; PlayerInfo[playerid][pPcarkey3] = 999; PlayerInfo[playerid][pAccount] = 500; PlayerInfo[playerid][pReg] = 1; } /*if(PlayerInfo[playerid][pLevel] == -999) //autoban { Ban(playerid); }*/ else if(PlayerInfo[playerid][pCK] > 0) { Kick(playerid); } ClearChatbox(playerid, 8); SendClientMessage(playerid, COLOR_GREEN, "============================================="); format(string2, sizeof(string2), " Teretulemast Ьhendatud Rollimдngu serverisse, %s.",playernamesplit[0]); SendClientMessage(playerid, COLOR_WHITE,string2); SendClientMessage(playerid, COLOR_GREEN, "============================================="); SendClientMessage(playerid, COLOR_WHITE, "Server skriptud: AruLa ning MadeMan poolt."); SendClientMessage(playerid, COLOR_WHITE, "MySQL: Martin & Nicholas."); SendClientMessage(playerid, COLOR_WHITE, "Mumble IP: urp.live.playcode.eu:7100"); SendClientMessage(playerid, COLOR_WHITE, "Koduleht: www.u-rp.com"); format(string2, sizeof(string2), "Hetkel jooksva skripti versioon: %s.",SCRIPT_VERSION); SendClientMessage(playerid, COLOR_WHITE, string2); if (PlayerInfo[playerid][pDonateRank] > 0) { SendClientMessage(playerid, COLOR_WHITE,"SERVER: Sa oled preemium konto kasutaja!"); } if (PlayerInfo[playerid][pLinked] == 0) { SendClientMessage(playerid, COLOR_LIGHTRED, "SERVER: Su kasuta pole aktiveeritud. Su хigused on piiratud!"); } if (PlayerInfo[playerid][pAdmin] > 0) { format(string2, sizeof(string2), "SERVER: Sa oled sisse logitud kui %d admin.",PlayerInfo[playerid][pAdmin]); SendClientMessage(playerid, COLOR_WHITE,string2); } SendClientMessage(playerid, COLOR_GREEN, "============================================="); SendClientMessage(playerid, COLOR_WHITE, " "); printf("%s has logged in.",playername2); // Unset Crash SetTimerEx("UnsetCrash", 5000, false, "i", playerid); SetSpawnInfo(playerid, PlayerInfo[playerid][pTeam], PlayerInfo[playerid][pModel], PlayerInfo[playerid][pPos_x], PlayerInfo[playerid][pPos_y], PlayerInfo[playerid][pPos_z], 1.0, -1, -1, -1, -1, -1, -1); if(gTeam[playerid] == 0) { gTeam[playerid] = 3; } else { gTeam[playerid] = PlayerInfo[playerid][pTeam]; } gPlayerLogged[playerid] = 1; SpawnPlayer(playerid); if(PlayerInfo[playerid][pCrashed] == 0) { format(tmp2, sizeof(tmp2), "~w~Tere Tulemast ~n~~y~ %s", playername2); } else { SendClientMessage(playerid, COLOR_WHITE, "SERVER: Teie ьhendus katkes teadmata pхhjusel ennem vдljumist."); SendClientMessage(playerid, COLOR_YELLOW2, "Crash sьsteem: Teie positsioon taastati.."); } DateProp(playerid); if(PlayerInfo[playerid][pFMember] < 255) { format(tmp2, sizeof(tmp2), "Family MOTD: %s.", FamilyInfo[PlayerInfo[playerid][pFMember]][FamilyMOTD]); SendClientMessage(playerid, COLOR_YELLOW, tmp2); } for(new i = 0; i < MAX_PLAYERS; i++) { if(IsPlayerConnected(i)) { if(PlayerInfo[i][pMaskuse] == 1) { ShowPlayerNameTagForPlayer(playerid, i, 0); } } } return 1; }
Originally Posted by MenaceX^
You should change your behavior because you are wrong. There is not a REPLACEMENT for mysql_strtok. E.g:
samp_mysql_fetch_row is here mysql_fetch_row_format. But there is NOTHING related to strtok in this plugin than fetching a whole row. |
Originally Posted by Albus_Dumbledore
Hi all !!
I am sorry to post here but i have a problem, and i know that you have ever speak of the samp_mysql_strtok, but i don't understand how can i do . My problem: I use moderntopia gm, when i /login on my server, it crash. In the script, there is: samp_mysql_strtok(Field, "|", Data); while (samp_mysql_strtok(Field, "|", "")==1) { What i have to do please ? I am working on it but i don't have any solution !! |
Originally Posted by $ЂЯĢ
This would be possible fix.
pawn Code:
|
Originally Posted by $ЂЯĢ
The only issue here can be that mysql_fetch_int doesn't do its job, so we make mysql_num_rows() to see if we got any data from SELECT query. If we got any data we fetch it in PlayerInfo[playerid][pSQLId]. If mysql_fetch_int() doesn't do its job we check if PlayerInfo[playerid][pSQLId] is higher than 0 (INVALID_SQL_ID). If it's not we know there is a data for that username already, but mysql_fetch_int didn't get row's ID which we wanted to get, so it's useless to continue that's why we kick player.
Understood? |
MySQL Connect Error: Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2) (Error ID: 2002)
[20:59:14] mysql_connect("*******","*******","*******","*******"); [20:59:14] MySQL Connect Error: Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2) (Error ID: 2002) [21:03:40] MySQL Ping Error: "MySQL server has gone away" [21:03:40] mysql_close();
Originally Posted by Monoxid
Hi, i got this error when i want to connect to the database:
Code:
MySQL Connect Error: Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2) (Error ID: 2002) Code:
[20:59:14] mysql_connect("*******","*******","*******","*******"); [20:59:14] MySQL Connect Error: Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock' (2) (Error ID: 2002) [21:03:40] MySQL Ping Error: "MySQL server has gone away" [21:03:40] mysql_close(); |
#define MAX_ANNOUNCEMENTS 10
enum rInfo
{
rName[30],
rText[128],
rContact[20],
rBusy
}new Recuiting[MAX_ANNOUNCEMENTS+1][rInfo];
stock LoadSQLRecuiting()
{
new totalannonce;
new Field[64];
new Data[256];
new sql[80];
format(sql, sizeof(sql), "SELECT COUNT(*) FROM annonces");
mysql_query(sql);
mysql_store_result();
mysql_fetch_row(Data);
totalannonce = strval(Data);
mysql_free_result();
for (new idx=1; idx<=totalannonce; idx++)
{
format(sql, sizeof(sql), "SELECT * FROM annonces WHERE id=%d", idx);
mysql_query(sql);
mysql_store_result();
if (mysql_num_rows() > 0)
{
mysql_fetch_row(Data);
mysql_fetch_field_row(Field,"name");
printf("%s, %d, %d", Field, totalannonce, idx);
strmid(Recuiting[idx][rName],Field,0,strlen(Field),50);
mysql_fetch_field_row(Field,"text");
printf("%s, %d", Field, totalannonce);
strmid(Recuiting[idx][rText],Field,0,strlen(Field),128);
mysql_fetch_field_row(Field,"contact");
printf("%s, %d", Field, totalannonce);
strmid(Recuiting[idx][rContact],Field,0,strlen(Field),20);
mysql_fetch_field_row(Field,"busy");
Recuiting[idx][rBusy] = strval(Field);
}
mysql_free_result();
}
printf("%d recuiting announcements loaded from DB.", totalannonce);
return 1;
}
[17:35:14][17:35:14] Sweeper, 10, 1 [17:35:14] Vous conduisez une balayeuse а travers Los Santos afin de nettoyer les rues, 101 [17:35:14] ((/sweeper)), 101 [17:35:14] Aucun, 101, 2 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101, 3 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101, 4 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101, 5 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101, 6 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101, 7 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101, 8 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101, 9 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101, 10 [17:35:14] Aucun, 101 [17:35:14] Aucun, 101 [17:35:14] 101 recuiting announcements loaded from DB. |
Originally Posted by Coicatak
Hi, I got a big problem that I can't fix for HOURS.
here's the buggy function, actually totalannonce is supposed to be 10 but after the line "mysql_fetch_field_row(Field,"text");" it magically sets itself to 101 for no appearent reason... pawn Code:
Quote:
This is really annoying, so if anyone could help me... Thanks |