←  Pytania

AMXX.pl: Support AMX Mod X i SourceMod

»

[MySQL] Odczytywanie wartości z tabel.

  • +
  • -
Mister Silenzo - zdjęcie Mister Silenzo 05.03.2014

Witam!
 
Postanowiłem pobawić się trochę pluginami z MySQL, a co za tym idzie, biblioteką "sqlx", już na samym początku napotykam problem, gdyż nie wiem w jaki sposób mam odczytać wartości z tabel i wypisać je w konsoli, a dokładniej, mam taki kod, który odpowiada za połączenie:
 
#include <amxmodx>
#include <sqlx>

new const HOST[] = "localhost";
new const USER[] = "root";
new const PASSWORD[] = "1234567";
new const DB[] = "cstrike_db";

new Handle:mysql;

public plugin_init() {
	register_plugin("TEST", "AUTORSKA", "MISTER SILENZO");
	
	mysql = SQL_MakeDbTuple(HOST, USER, PASSWORD, DB);
	
	new errcode, error[64];
	SQL_Connect(mysql, errcode, error, sizeof(error));
	
	if(errcode == 0) server_print("Polaczenie z baza nawiazane! Baza danych: %s!", DB);
	else {
		new string[128];
		formatex(string, sizeof(string), "Wystapil blad! Kod bledu %i o tresci %s!", errcode, error);
		server_print(string);
		set_fail_state(string);
	}
}
Bazę danych postawiłem na PC poprzez XAMPP'a a jako interfejsu graficznego bazy danych używam HeidiSQL. W interfejsie baza wygląda tak.

0ghdEhX.png

Jest stworzona baza danych o nazwie cstrike_db, w bazie jest tabela o nazwie "konta" a w tabeli są trzy rekordy o właściwościach podanych na screenie.

Teraz chcę ze wszystkich dostępnych rekordów odczytać wartość ID, nick i punkty i wypisać je w konsoli serwera (server_print) w takiej postaci "ID: %i ma nick %s. Jego punkty: %i". Proszę o dokładne wytłumaczenie wszystkich przeprowadzanych operacji, z góry dziękuję za pomoc :>

PS. Czytałem tematy typu "MySQL, z czym to się je", etc., lecz niezbyt do mnie przemówiły ;/
Odpowiedz

  • +
  • -
GwynBleidD - zdjęcie GwynBleidD 05.03.2014

http://amxx.pl/topic...czym-to-sie-je/ zacznij od tego poradnika :) w AMXX obsługa SQL nie wygląda tak kolorowo, jak w np PHP (chociaż i tam nie wygląda kolorowo jeśli ktoś nie używa PDO lub mysqli tylko męczy się na przestarzałych funkcjach mysql) bo nie mamy w AMXX łatwo dostępnych tablic wielowymiarowych podawanych jako parametry do funkcji. Nie mamy również kompletnie struktur ani obiektowości, więc trzeba każdą komórkę wyłuskiwać oddzielnie, ale gdy się już ma gotową i stałą strukturę bazy danych to można sobie pod tą konkretna strukturę odpowiednie funkcje napisać, które nam to ułatwiają :)

Odpowiedz

  • +
  • -
Mister Silenzo - zdjęcie Mister Silenzo 06.03.2014

Dobra, przeczytałem to jeszcze raz i dokładnie, teraz moje kolejne pytanie.

Odczytać wartość z tabeli i danego wiersza mogę zrobić tylko po wywołaniu komendy SQL (w przypadku mojej bazy) "SELECT 'nick', 'punkty' FROM 'konta' WHERE 'nick'='%s';" i teraz żeby odczytać ilość punktów z tablicy muszę zrobić to w publicu, który jest wywoływany przez SQL_ThreadQuery?

@EDIT

Skleciłem coś takiego:

#include <amxmodx>
#include <sqlx>

new const HOST[] = "127.0.0.1";
new const USER[] = "root";
new const PASSWORD[] = "";
new const DB[] = "cstrike_db";

new Handle:mysql;

public plugin_init() {
	register_plugin("TEST", "AUTORSKA", "MISTER SILENZO");
	
	mysql = SQL_MakeDbTuple(HOST, USER, PASSWORD, DB);
	
	new errcode, error[64];
	SQL_Connect(mysql, errcode, error, sizeof(error));
	
	if(errcode == 0) server_print("Polaczenie z baza nawiazane! Baza danych: %s!", DB);
	else {
		new string[128];
		formatex(string, sizeof(string), "Wystapil blad! Kod bledu %i o tresci %s!", errcode, error);
		server_print(string);
		set_fail_state(string);
	}
	
	register_concmd("amx_save", "save_user");
}

public save_user(id) {
	new cQuery[256], name[32], punkty;
	get_user_name(id, name, 31);
	punkty = 50;
	formatex(cQuery, sizeof(cQuery), "INSERT INTO `konta` (`nick`, `punkty`) VALUES ('%s', %i);", name, punkty);
	
	SQL_ThreadQuery(mysql, "SaveH_", cQuery);
}

public SaveH_(FailState, Handle:Query, Errorcode, Error[], Data[], DataSize)
{
	if(Errorcode) log_amx("Blad w zapytaniu: %s [SaveData] %i", Error, Errorcode);
	
	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 [SaveData]");
		return PLUGIN_CONTINUE
	}
	log_amx("Zapis Udany! [SaveData]");
	return PLUGIN_CONTINUE
}
Jest jednak jeden problem, w logach wyskakuje takie coś:

L 03/06/2014 - 14:56:05: [amx_ip.amxx] Blad w zapytaniu: 127.0.0.1 [SaveData] 1440
L 03/06/2014 - 14:56:05: [amx_ip.amxx] Zapis Udany! [SaveData]
I pomimo tego zapis się udaje, czy ktoś może mi wytłumaczyć czym jest spowodowany ten bug?
Użytkownik Mister Silenzo edytował ten post 06.03.2014 14:58
Odpowiedz

  • +
  • -
GwynBleidD - zdjęcie GwynBleidD 06.03.2014

Zamień miejscami parametry Errorcode i Error. Poza tym gdy wywołujesz komunikat błędu:

    if(Errorcode) log_amx("Blad w zapytaniu: %s [SaveData] %i", Error, Errorcode);

to już raczej nie wykonujesz komunikatu sukcesu. W tym miejscu powinieneś wyjść z funkcji.

Odpowiedz

  • +
  • -
Mister Silenzo - zdjęcie Mister Silenzo 06.03.2014

Zamieniłem. Sam zapis działa teraz prawidłowo, tylko nadal nie wiem jak mam odczytywać to co już, np. stworzyłem za pomocą edytora graficznego bazy danych.


Użytkownik Mister Silenzo edytował ten post 06.03.2014 19:51
Odpowiedz

  • +
  • -
GwynBleidD - zdjęcie GwynBleidD 06.03.2014

I tak i nie. Bo nie w tym miejscu miałeś zamienić kolejność, ale 2 linijki wyżej.

Odpowiedz