Skocz do zawartości

Witamy w Nieoficjalnym polskim support'cie AMX Mod X

Witamy w Nieoficjalnym polskim support'cie AMX Mod X, jak w większości społeczności internetowych musisz się zarejestrować aby móc odpowiadać lub zakładać nowe tematy, ale nie bój się to jest prosty proces w którym wymagamy minimalnych informacji.
  • Rozpoczynaj nowe tematy i odpowiedaj na inne
  • Zapisz się do tematów i for, aby otrzymywać automatyczne uaktualnienia
  • Dodawaj wydarzenia do kalendarza społecznościowego
  • Stwórz swój własny profil i zdobywaj nowych znajomych
  • Zdobywaj nowe doświadczenia

Dołączona grafika Dołączona grafika

Guest Message by DevFuse
 

Zdjęcie

Błąd zapytania SQLBłąd w zapytaniu: HamFilter

sql hamfilter zapytanie błąd

  • Nie możesz napisać tematu
  • Zaloguj się, aby dodać odpowiedź
2 odpowiedzi w tym temacie

#1 DarkLink

    Początkujący

  • Użytkownik

Reputacja: 0
Nowy

  • Postów:15
  • GG:
  • Imię:Ariel
  • Lokalizacja:Gdynia
Offline

Napisano 06.03.2015 17:38

Witam, kilka dni temu zacząłem się uczyć pisania pluginów, no i napotkałem problem przy sql, a dokładniej łączy mnie z bazą danych, ale nie mogę zwrócić żadnych wyników, a zwracany błąd to "HamFilter" i nie wiem o co dokładniej chodzi :/ Mam dosyć spore doświadczenie w pisaniu kodów, a przynajmniej rozumiem co i jak :D ale w PAWN'ie nigdy nie pisałem.

Oto kod:

#include <amxmodx>
#include <amxmisc>
#include <cstrike>
#include <engine>
#include <fakemeta>
#include <fun>
#include <hamsandwich>
#include <sqlx>

#define PLUGIN "Mysql"
#define VERSION "1.0"
#define AUTHOR "DarkLink"

new Handle:gTuple;

public plugin_init() {
	register_plugin(PLUGIN, VERSION, AUTHOR)
	register_clcmd("say test","CheckData",ADMIN_KICK,"Testuje polaczenie")
	gTuple = SQL_MakeDbTuple("host","uzytkownik","haslo","baza")
}

public CheckData(id){

new Data[1]
Data[0] = id;
new qCommand[512], szName[32]
get_user_name(id, szName, charsmax(szName))
format(qCommand, sizeof qCommand-1, "SELECT * FROM `jml_cs_curskin` WHERE `nick` = '%s'", szName)
SQL_ThreadQuery(gTuple, "CheckHandler", qCommand, Data, 1)
}

public CheckHandler(FailState, Handle:Query, Errorcode, Error[], Data[], DataSize)
{
new id = Data[0]
if(Errorcode)
log_amx("Blad w zapytaniu: %s [CheckData]", Error)

if(FailState == TQUERY_CONNECT_FAILED)
{
log_amx("Nie mozna podlaczyc sie do bazy danych.")
return PLUGIN_CONTINUE
}
else if(FailState == TQUERY_QUERY_FAILED)
{
log_amx("Zapytanie anulowane [CheckData]")
return PLUGIN_CONTINUE
}

if(!SQL_MoreResults(Query))
log_amx("Brak danych!")
else
{
new zwrot[1];
zwrot[0] = SQL_ReadResult(Query, SQL_FieldNameToNum(Query, "userid"));
client_print(id,print_chat,zwrot[0])
}

return PLUGIN_CONTINUE
}

Natomiast zwracana wartość po wpisaniu w konsoli "say test" lub w say'u "test" to:

 

L 03/06/2015 - 17:16:50: [testsql.amxx] Blad w zapytaniu: HamFilter [CheckData]

Prosiłbym o pomoc :)

 

//Edit:

Zmieniając linijki od 53. do 55. na:

new szText[128];
SQL_ReadResult(Query, SQL_FieldNameToNum(Query, "userid"), szText, 127);
console_print(id,"Tekst: %s", szText)

Wyświetla mi

 

Tekst: 986

Czyli to co chciałem, ale nadal wyrzuca ten błąd w zapytaniu: HamFilter, nie wie ktoś o co chodzi?


Użytkownik DarkLink edytował ten post 06.03.2015 17:48

  • +
  • -
  • 0

Zapraszam na Ponad Granice

b_350_20_692108_381007_FFFFFF_000000.png

 

Pamiętaj! Nie pomagam na PW/GG chyba że odpłatnie.

Zanim do mnie napiszesz zastanów się 2 razy nad sensem swojej wypowiedzi.

Jeśli masz takowe zlecenie pisz GG:11351931


#2 Biometr

    Początkujący

  • Oczekujący

Reputacja: 3
Nowy

  • Postów:17
  • Lokalizacja:Internet
Offline

Napisano 24.03.2015 23:51

#include <amxmodx>
#include <amxmisc>
#include <cstrike>
#include <engine>
#include <fakemeta>
#include <fun>
#include <hamsandwich>
#include <sqlx>

Po co ładujesz wszystko, zostaw tylko to czego używasz a problem zniknie.

 


  • +
  • -
  • -1

#3 GwynBleidD

    Godlike

  • Przyjaciel

Reputacja: 1 869
Godlike

  • Postów:3 066
  • Steam:steam
  • Lokalizacja:Przemyśl
Offline

Napisano 25.03.2015 15:06

@ Biometr taa, jak ręką odjął normalnie... Moduły absolutnie nie wpływają na to, jak plugin działa (no chyba, że któryś celowo modyfikuje jego działanie lub jest uszkodzony, a to nie ten przypadek). A widać są potrzebne (we fragmencie pluginu, który nie został zamieszczony?).
 
@ DarkLink, problem znajduje się tu:
 
public CheckHandler(FailState, Handle:Query, Errorcode, Error[], Data[], DataSize)
Masz zamienioną kolejność parametrów, powinno być:
 
public CheckHandler(FailState, Handle:Query, Error[], Errorcode, Data[], DataSize)
Przez tą zamianę kompletne zamieszanie się dzieje w kodzie.

Napisz skąd wytrzasnąłeś tą kolejność parametrów, bo przydałoby się ją zmienić u źródła, nie pierwszy raz widzę tego babola więc sądzę, że gdzieś w necie ten babol wisi...
sebul (25.03.2015 15:33):
Bardzo prawdopodobne, że gdzieś u nas jest ten babol ^ ^
GwynBleidD (25.03.2015 22:24):
Dlatego poprosiłem o źródło, bo jak boga kocham sam kiedyś na to trafiłem :)
GwynBleidD (25.03.2015 22:32):
http://amxx.pl/topic...ię-je/?p=144797 znalazłem i poprawiłem, dziękuję bardzo :)

  • +
  • -
  • 1

NIE pomagam na PW. Nie trudź się, na zlecenia nie odpiszę... Od pomagania jest forum.
NIE zaglądam w tematy wysłane na PW. Jeśli są na forum to prędzej czy później je przeczytam. Jeśli mam co w nich odpisać, to odpiszę.
 
1988650.png?theme=dark






Również z jednym lub większą ilością słów kluczowych: sql, hamfilter, zapytanie, błąd

Użytkownicy przeglądający ten temat: 0

0 użytkowników, 0 gości, 0 anonimowych