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
 

Dokumentacja AMX Mod X v. 11.5 Uzupełnionych funkcji: Sortowanie: Według modułów | Alfabetycznie
Szukaj funkcji:

3rdParty
Core
Cstrike
CSX
DoDX
Engine
ESF
Fakemeta
Fun
fun
GeoIP
HamSandwich
JSON
NS
nVault
REAPI
Regex
Sockets
Sql
SQLx
dbi
TFCX
TSFUN
TSX
tsx

SQL_GetInsertId

Dodane 28.03.2014 19:07 przez: SeeK
#
  


Opis

Funkcja zwraca ID wygenerowane w ostatnim zapytaniu np. poprzez ustawienie kolumnie atrybutu AUTO_INCREMENT

Składnia

SQL_GetInsertId(Handle:query)

Typ

Natywny

Notatki

Handle:query



Przykład

public stworzTabele() {
	formatex(szTemp,charsmax(szTemp),"CREATE TABLE IF NOT EXISTS `gracze` ( \
						gid int(10) UNIQUE AUTO_INCREMENT, \
						name varchar(32)\
						)")
	SQL_ThreadQuery(g_SqlTuple,"IgnoreHandle",szTemp)
}

public pobierzIdGracza(id) {
	if(!is_user_connected(id))
		return
	
	new Data[1]; Data[0] = id
	new name[64]
	get_user_name(id,name,charsmax(name))
	replace_all(name,charsmax(name),"'","\'")
	formatex(szTemp,charsmax(szTemp),"SELECT `gid` \
						FROM `gracze` \
						WHERE `name` = '%s'",name)
	SQL_ThreadQuery(g_SqlTuple,"pobierzIdGracza_handle",szTemp,Data,1)
}
public pobierzIdGracza_handle(FailState,Handle:Query,Error[],Errorcode,Data[],DataSize) {
	if(Errorcode) {
		// Blad w zapytaniu, można dodać jakieś info
		return
	}
	
	new id = Data[0]
	// Brak danych o graczu
	if(SQL_NumResults(Query) <= 0) {
		new name[64]
		get_user_name(id,name,charsmax(name))
		replace_all(name,charsmax(name),"'","&#092;'")
		
		formatex(szTemp,charsmax(szTemp),"INSERT INTO `%s` ( `name` ) &#092;
						VALUES ( '%s' )",name)
		SQL_ThreadQuery(g_SqlTuple,"dodajGracza_handle",szTemp,Data,1)
		return
	}
	
	// Pobieranie id gracza
	id_gracza[id] = SQL_ReadResult(Query, SQL_FieldNameToNum(Query,"gid"))
}
public baza_dodajGracza_handle(FailState,Handle:Query,Error[],Errorcode,Data[],DataSize) {
	if(Errorcode) {
		// Blad w zapytaniu, można dodać jakieś info
		return
	}
	new id = Data[0]
	id_gracza[id] = SQL_GetInsertId(Query)
}




Zakaz używania, kopiowania i innego wykorzystywania treści witryny oraz innych materiałów w niej zawartych bez zgody autorów. Wszelkie prawa zastrzeżone. © 2009-2024