Вопросы

Всем привет, у меня проблема с выводом полного списка организации!

Вот скриншет: https://ibb.co/XZHXD2J

 

Вот сам код:

Спойлер

if(!response) return true;
switch(listitem)
{
	case 0: //return SEM(playerid, "[Система] Ждите доработки системы!");
	{
		mysql_format(Baza, stringer,sizeof(stringer), "SELECT * FROM "T_ACCOUNTS" WHERE `Frac` = '%i'", PI[playerid][pFrac]);
		mysql_tquery(Baza, stringer, "AllFrac", "i", playerid);
		return true;
	}
}
Спойлер


forward AllFrac(playerid);
public AllFrac(playerid)
{
   	new rows;
	cache_get_row_count(rows);
	new string[72];
	strcat(stringer, "{FFFF00}Имя сотрудника\t{FFFF00}Должнасть сотрудника\t{FFFF00}Последний вход\t{FFFF00}Статус\n");
	if(rows)
	{
	    for(new i = 0; i < rows; i++)
	    {
	        cache_get_value_name(0, "Name", GetName(i), MAX_PLAYER_NAME);
			cache_get_value_name_int(0, "FracRang", PI[i][pFracRang]);
			cache_get_value_name(0, "DataVhod", PI[playerid][pDataVhod], 20);
			cache_get_value_name_int(0, "Game", Game(i));

			format(string, sizeof(string), "\n{FFFFFF}%s\t%s - (%d)\t%s\t%s\n", GetName(i), Frac_Rang[GetFrac(i)][PI[i][pFracRang]-1], PI[i][pFracRang], PI[i][pDataVhod], (Game(i) == 1)?("{00FF00}В игре"):("{FF0000}Нет в игре"));
			strcat(stringer, string);
	  		//if(PI[i][pFracRang] == 10) continue;
		}
		SPD(playerid, dNull, DIALOG_STYLE_TABLIST_HEADERS, "{FFCC00}Список сотрудников органзации", stringer, "Закрыть", "");
	}
	else if(!rows) return SPD(playerid, dNull, DIALOG_STYLE_TABLIST_HEADERS, "{FFCC00}Список сотрудников органзации", "В даноой организации нет сотрудников!", "Закрыть", "");
	return true;
}

 

 

 

Поделиться сообщением


Ссылка на сообщение

4 ответа на этот вопрос

  • 0

@Andrey_Akkerman, если используете глобальную переменную под строки, то не забывайте ее очищать. Замените код получения данных этим:

Спойлер

forward AllFrac(playerid);
public AllFrac(playerid)
{
   	new rows;
	cache_get_row_count(rows);
	new string[72];
	stringer = '\0';
	strcat(stringer, "{FFFF00}Имя сотрудника\t{FFFF00}Должнасть сотрудника\t{FFFF00}Последний вход\t{FFFF00}Статус\n");
	if(rows)
	{
	    for(new i = 0; i < rows; i++)
	    {
	        cache_get_value_name(0, "Name", GetName(i), MAX_PLAYER_NAME);
			cache_get_value_name_int(0, "FracRang", PI[i][pFracRang]);
			cache_get_value_name(0, "DataVhod", PI[playerid][pDataVhod], 20);
			cache_get_value_name_int(0, "Game", Game(i));

			format(string, sizeof(string), "\n{FFFFFF}%s\t%s - (%d)\t%s\t%s\n", GetName(i), Frac_Rang[GetFrac(i)][PI[i][pFracRang]-1], PI[i][pFracRang], PI[i][pDataVhod], (Game(i) == 1)?("{00FF00}В игре"):("{FF0000}Нет в игре"));
			strcat(stringer, string);
	  		//if(PI[i][pFracRang] == 10) continue;
		}
		SPD(playerid, dNull, DIALOG_STYLE_TABLIST_HEADERS, "{FFCC00}Список сотрудников органзации", stringer, "Закрыть", "");
	}
	else if(!rows) return SPD(playerid, dNull, DIALOG_STYLE_TABLIST_HEADERS, "{FFCC00}Список сотрудников органзации", "В даноой организации нет сотрудников!", "Закрыть", "");
	return true;
}

 

 

Поделиться сообщением


Ссылка на сообщение
  • 0
В 04.03.2019 в 17:18, odosenok сказал:

@Andrey_Akkerman, если используете глобальную переменную под строки, то не забывайте ее очищать. Замените код получения данных этим:

  Код (открыть спойлер)


forward AllFrac(playerid);
public AllFrac(playerid)
{
   	new rows;
	cache_get_row_count(rows);
	new string[72];
	stringer = '\0';
	strcat(stringer, "{FFFF00}Имя сотрудника\t{FFFF00}Должнасть сотрудника\t{FFFF00}Последний вход\t{FFFF00}Статус\n");
	if(rows)
	{
	    for(new i = 0; i < rows; i++)
	    {
	        cache_get_value_name(0, "Name", GetName(i), MAX_PLAYER_NAME);
			cache_get_value_name_int(0, "FracRang", PI[i][pFracRang]);
			cache_get_value_name(0, "DataVhod", PI[playerid][pDataVhod], 20);
			cache_get_value_name_int(0, "Game", Game(i));

			format(string, sizeof(string), "\n{FFFFFF}%s\t%s - (%d)\t%s\t%s\n", GetName(i), Frac_Rang[GetFrac(i)][PI[i][pFracRang]-1], PI[i][pFracRang], PI[i][pDataVhod], (Game(i) == 1)?("{00FF00}В игре"):("{FF0000}Нет в игре"));
			strcat(stringer, string);
	  		//if(PI[i][pFracRang] == 10) continue;
		}
		SPD(playerid, dNull, DIALOG_STYLE_TABLIST_HEADERS, "{FFCC00}Список сотрудников органзации", stringer, "Закрыть", "");
	}
	else if(!rows) return SPD(playerid, dNull, DIALOG_STYLE_TABLIST_HEADERS, "{FFCC00}Список сотрудников органзации", "В даноой организации нет сотрудников!", "Закрыть", "");
	return true;
}

 

Вот в итоги что получилось!

 

Изображение "КЛИКАБЕЛЬНО"!

Поделиться сообщением


Ссылка на сообщение
  • 0

@Andrey_Akkerman, покажите SQL запрос, которым грузите эти данные.

Поделиться сообщением


Ссылка на сообщение
  • 0
2 часа назад, odosenok сказал:

@Andrey_Akkerman, покажите SQL запрос, которым грузите эти данные.

 

Спойлер

		case dlMenu:
		{
		    if(!response) return true;
		    switch(listitem)
		    {
		        case 0:
				{
					foreach(new i: Player)
					{
	                    format(stringer, sizeof(stringer), "SELECT * FROM "T_ACCOUNTS" WHERE Frac = '%d'", GetFrac(i));
						mysql_tquery(Baza, stringer, "AllFrac", "i", playerid);
					}
				}
			}
		}

Он меня одного показывает, а когда я создаю новый фккаунт то происходит то что ни скрине!

 

Отредактировано пользователем Andrey_Akkerman

Поделиться сообщением


Ссылка на сообщение
Гость
Эта тема закрыта для публикации ответов.
  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

  • Похожий контент

    • Узбек
      От Узбек
      Всем добрый вечер ребят! 
      Я начинающий, сегодня я вам сливаю команду 2(шт) на технические работы
      Ловите 
       
    • nazpol9
      От nazpol9
      Привет всем.

      У меня имеется мод для самп сервера и VPS с Ubuntu, на котором я пытаюсь его запустить.

      В чем суть проблемы: при запуске samp03svr, сервер запускается, но на версии 0.3.DL R-1. Когда я пытаюсь запустить этот же мод локально на Windows, сервер работает на версии 0.3.7 и я могу зайти на него без клиента 0.3.DL.

      Для решения этой проблемы я уже пробовал заменять инклуды и исполнительные файлы теми, что есть в архивах на официальном сайте сампа, перекомпилировал мод, и ничего не изменилось.
       
      #include <a_samp> #include <a_mysql> #include <foreach> #include <Pawn.RakNet> #include <streamer> #include <sscanf2> #include <float2> #include <crashdetect> #include <fmt> #include <a_http> #include <Pawn.CMD> #include <Pawn.Regex> #include <requests> #include <callbacks> #include <MD5> #include <mxdate> #include <TOTP> #include <gvar> #include <md-sort> #include <nex-ac> #include <weapon-config> #include <discord-connector> #include <3DTryg> #include <textdraw-streamer>  
      plugins crashdetect.so streamer.so textdraw-streamer.so sscanf.so pawnraknet.so pawncmd.so mysql.so requests.so profiler.so pawnregex.so TOTP.so gvar.so discord-connector.so

      Если у кого-то будут какие-либо догадки, прошу ими поделиться, если понадобится больше информации - я постараюсь её предоставить.