Jump to content
Дизайн и модификация IPS Community IPBSkinsBETA
Search In
  • More options...
Find results that contain...
Find results in...
Sign in to follow this  
TemKa_SD

C++ гляньте код

Recommended Posts

Здравствуйте, есть кто знает C++?. Я тут реализовал вывод ошибок и выполнение результата, это что-то первое моё на C++, только начал разбирать этот язык.

 

Был такой код, который просто возвращал верный результат, если было что обновлять, даже если данные введены не правильно. Оно не обновляло, но клиенту выдавало сообщение об успехе.

string UpdateQuery = "UPDATE wc3_gameplayers_connected SET status = 'approved' WHERE name='" + EscName + "' AND token='" + EscToken + "' AND server='" + EscRealm + "';";

if( mysql_real_query( (MYSQL *)conn, UpdateQuery.c_str( ), UpdateQuery.size( ) ) != 0 )
*error = mysql_error( (MYSQL *)conn );
else
result = 1;

return result;

 

Переписанный код с выводом правильных результатов:

 

string ExistQuery = "SELECT name, server, token FROM wc3_gameplayers_connected WHERE name='" + EscName + "' AND server='" + EscRealm + "'";
bool Exists = false;

// ExistQuery - выбираем текущие данные по имени и серверу, если всё в порядке, продолжаем работать, иначе, что-то пошло не так.
if( mysql_real_query( (MYSQL *)conn, ExistQuery.c_str( ), ExistQuery.size( ) ) == 0 )
{
MYSQL_RES *Result = mysql_store_result( (MYSQL *)conn );

if( Result )
{
	vector<string> Row = MySQLFetchRow( Result );
	// Если строка существует по имени и серверу, продолжаем работать, иначе выведем сообщение #2
	if( !Row.empty( ) )
	{
		Exists = true;

		// Если токен из базы соответствует вводимому, обновляем и выдаем успешный результат с сообщением #1, иначе выводим сообщение 
		if( Row[2] == EscToken )
		{
			string UpdateQuery = "UPDATE wc3_gameplayers_connected SET status = 'approved' WHERE name='" + EscName + "' AND token='" + EscToken + "' AND server='" + EscRealm + "';";

			if( mysql_real_query( (MYSQL *)conn, UpdateQuery.c_str( ), UpdateQuery.size( ) ) != 0 )
				*error = mysql_error( (MYSQL *)conn );
			else
				result = 1;
		}
		else
			result = 3;
	}
	else 
		result = 2;

	mysql_free_result( Result );
}
}
else
{
*error = mysql_error( (MYSQL *)conn );

return result;

 

Всё вроде работает правильно, что скажите?

Edited by TemKa_SD

Share this post


Link to post
Share on other sites

есть кто знает C++

Навряд ли. Тут в основном тру пэхапешники.

  • Upvote 1

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

  • Recently Browsing   0 members

    No registered users viewing this page.

×
×
  • Create New...