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
 

KariiO - zdjęcie

KariiO

Rejestracja: 24.12.2009
Aktualnie: Nieaktywny
Poza forum Ostatnio: 28.03.2018 18:16
-----

Moje posty

W temacie: Sql - czy nazwa istnieje

19.05.2013 21:17

Wiem że wystarczy zmienić ale nie o to mi chodziło :D Mnie mam że jak to użyje to zwróci tylko jednego użytkownika tak ? Bo nie wiem ilu ich jest :)

O SQL_NextRow w dokumentacji dużo nie ma więc powiedz coś od siebie :)

 

Edit1

Póki co coś takiego wyszkrobałem :

public sprawdz_nicki_czlonkow_party(id,party[])
{
new data[33]
data[0] = id
copy(data[1], 31, party);

new host[128]
new user[64]
new pass[64]
new database[64]

get_cvar_string("party_sql_database",database,63)
get_cvar_string("party_sql_host",host,127)
get_cvar_string("party_sql_user",user,63)
get_cvar_string("party_sql_pass",pass,63)
get_cvar_string("party_sql_table",g_sqlTable,63)

g_SqlTuple = SQL_MakeDbTuple(host,user,pass,database)

new q_command[512]
format(q_command,511,"SELECT * FROM `%s` WHERE `np`='%s' ",g_sqlTable,party)
SQL_ThreadQuery(g_SqlTuple,"SelectHandley",q_command,data,32)
}

public SelectHandley(FailState,Handle:Query,Error[],Errcode,Data[],DataSize)
{
new id= Data[0]
if(Errcode)
{
log_to_file("addons/amxmodx/logs/diablo.log","Error on load_xp query: %s",Error)
}
if(FailState == TQUERY_CONNECT_FAILED)
{
log_to_file("addons/amxmodx/logs/diablo.log","Could not connect to SQL database.")
return PLUGIN_CONTINUE
}
else if(FailState == TQUERY_QUERY_FAILED)
{
log_to_file("addons/amxmodx/logs/diablo.log","load_xp Query failed.")
return PLUGIN_CONTINUE
}


new chwyc= SQL_FieldNameToNum(Query, "nick")

new przypisz[512]

SQL_ReadResult(Query, chwyc, przypisz, 511)

client_print(id,print_chat,"Gracz %s jest w twoim party !",przypisz)


return PLUGIN_CONTINUE
}

W temacie: Losowy item

19.05.2013 19:52

Nic z Twojego postu nie  rozumiem, jedynie pierwsze zdanie.

W temacie: Sql - czy nazwa istnieje

19.05.2013 18:37

Okej śmiga wszystko :) Dzięki, nie wiem czy moje by zadziałało czy nie ale do tej pory nie działało bo pomyliłem sobie miejsca w funkcji copy...

Druga sprawa, jak mogę pobrać wszystkie rekordy które są w danej kolumnie ? Chodzi mi przykladowo o pobranie wszystkich nicków gdzie nazwa drużyny jest jakaś tam ?

W temacie: Sql - czy nazwa istnieje

19.05.2013 11:19

Nie robię na około na pewno ponieważ tworzę nazwę ale nie może być dwóch takich samych więc muszę sprawdzić czy w bazie taka istenieje.

Chodzi mi o rekord w danej tabeli, niby kod mam taki ale czy dobry...:

public sprawdz_nazwe_party(id,party[])
{
new data[1]
data[0] = id

new host[128]
new user[64]
new pass[64]
new database[64]

get_cvar_string("party_sql_database",database,63)
get_cvar_string("party_sql_host",host,127)
get_cvar_string("party_sql_user",user,63)
get_cvar_string("party_sql_pass",pass,63)
get_cvar_string("party_sql_table",g_sqlTable,63)

g_SqlTuple = SQL_MakeDbTuple(host,user,pass,database)

new q_command[512]
format(q_command,511,"SELECT * FROM `%s` WHERE `np`='%s' ",g_sqlTable,party)

SQL_ThreadQuery(g_SqlTuple,"SelectHandley",q_command,data,1)
}

public SelectHandley(FailState,Handle:Query,Error[],Errcode,Data[],DataSize)
{
new id= Data[0]
if(Errcode)
{
log_to_file("addons/amxmodx/logs/diablo.log","Error on load_xp query: %s",Error)
}
if(FailState == TQUERY_CONNECT_FAILED)
{
log_to_file("addons/amxmodx/logs/diablo.log","Could not connect to SQL database.")
return PLUGIN_CONTINUE
}
else if(FailState == TQUERY_QUERY_FAILED)
{
log_to_file("addons/amxmodx/logs/diablo.log","load_xp Query failed.")
return PLUGIN_CONTINUE
}


new chwyc = SQL_FieldNameToNum(Query, "np")


new przypisz[512]

SQL_ReadResult(Query, chwyc, przypisz, 511)

if(equal(sprawdzane_party[id],przypisz))
{
client_print(id,print_chat,"[PARTY] Party o nazwie %s juz istnieje !",sprawdzane_party[id])
glowne_menu_party(id)
}
else
{
client_print(id,print_chat,"[PARTY] Nazwa %s jest wolna !",sprawdzane_party[id])
glowne_menu_party(id)
}

return PLUGIN_CONTINUE
}

W temacie: Losowy item

19.05.2013 01:12

Kolega chce dodać klasie losowy perk ale nie ma takiego natywu więc bawi się omijając natywy chodź nie wiem w jaki sposób choć moze callfunc itd...

Dodaj do klasy:

new pluginid=find_plugin_byfile("diablo_nowe.amxx");//jezeli glowny plugin ma inna nazwe zmien ja
new funckjaid=get_func_id("giveUserItem", pluginid);

callfunc_begin_i(funckjaid, pluginid);
callfunc_push_int(id);
callfunc_push_int(0);
callfunc_end();