Рекомендованные сообщения



10 posts in this topic

Всем привет. Кто сможет подсказать как соединить 2 таблицы?
Допустим:
1 Таблица информация о Игроке
2 Таблица информация о фракции

В первой таблице пишется ID фракции, а во второй описание по этому иду.
Дак вот, вопрос вот в чем, как сделать так, что если в 1 таблице стоит ид 1, то ему выдавалась информация по первой фракции?
Есть предложение, что так

pInfo[playerid][fID] = fInfo[playerid][ID]


или же это глупость? Буду очень сильно благодарен за помощь)

Share this post


Link to post
Share on other sites

В таблице с игроком храните ID фракции, а фракции грузите как обычно. Тогда обращаться можно будет так

new fractionId = pInfo[playerid][fID];

fInfo[fractionId][...]

 

Share this post


Link to post
Share on other sites
В 19.03.2020 в 15:22, DEST сказал:

В таблице с игроком храните ID фракции, а фракции грузите как обычно. Тогда обращаться можно будет так


new fractionId = pInfo[playerid][fID];

fInfo[fractionId][...]

 

Выдает ошибку 

error 001: expected token: ",", but found "["
error 029: invalid expression, assumed zero
error 091: ambiguous constant; tag override is required (symbol "Name")
fatal error 107: too many error messages on one line

при следующем коде

new fID = pInfo[playerid][Member];
static const fmt_str[] = "Вы состоите в Организации - %s";
new string[sizeof(fmt_str)+5];
format(string, sizeof(string), fmt_str, fInfo[fID][Name]);
SCM(playerid, COLOR_RED, string);

 

Что я хотел бы увидеть в этом коде, чтобы если игрок состоит в организации под ID 1 ( Member = 1 ), то игроку выводило бы сообщение Вы состоите в Организации - ( допустим ) ЛСПД. 

Edited by DaGroIII

Share this post


Link to post
Share on other sites

@DaGroIII как fInfo объявлено? 

Share this post


Link to post
Share on other sites
14 минут назад, DEST сказал:

@DaGroIII как fInfo объявлено? 

new fInfo[FractionInfo]

Если сделать

new fInfo[MAX_PLAYERS]

тогда ругается сток загрузки, что нету переменной (playerid)
А если добавить (playerid), то нужно ли так? 

 

Edited by DaGroIII

Share this post


Link to post
Share on other sites

@DaGroIII Вам массив нужен двумерный, так как для каждой фракции есть какое-то количество параметров. Т.е. объявление будет следующего вида: 

new fInfo[?][??];
// ? - количество фракций
// ?? - количество параметров для каждой из фракций, например: название, количетсво рангов, и пр. Обычно для этого используют дополнительно enum, чтобы не запоминать по какому номеру что лежит: 
enum fInfo_enum
{
	Name[15],
	maxRanks,
	...
};
new fInfo[MAX_FRACTIONS][fInfo_enum];

 

Share this post


Link to post
Share on other sites

@DEST Сейчас ругается на этот код.. Что тут может быть не так?

stock LoadFraction()
{
	mysql_query(Database, "SELECT * FROM `Fraction`");
	cache_get_value_name_int(0, "ID", fInfo[ID]);
	cache_get_value_name(0, "Name", fInfo[Name]);
	cache_get_value_name(0, "Rank1", fInfo[Rank1]);
	cache_get_value_name(0, "Rank2", fInfo[Rank2]);
	cache_get_value_name(0, "Rank3", fInfo[Rank3]);
	cache_get_value_name(0, "Rank4", fInfo[Rank4]);
	cache_get_value_name(0, "Rank5", fInfo[Rank5]);
	cache_get_value_name(0, "Rank6", fInfo[Rank6]);
	cache_get_value_name(0, "Rank7", fInfo[Rank7]);
	cache_get_value_name(0, "Rank8", fInfo[Rank8]);
	cache_get_value_name(0, "Rank9", fInfo[Rank9]);
	cache_get_value_name(0, "Rank10", fInfo[Rank10]);
}

А вот все остальное связанное с ним

#define MAX_FRACTIONS 28

enum FractionInfo
{
	ID,
	Name[32],
	Rank1[32],
	Rank2[32],
	Rank3[32],
	Rank4[32],
	Rank5[32],
	Rank6[32],
	Rank7[32],
	Rank8[32],
	Rank9[32],
	Rank10[32]
}

new fInfo[MAX_FRACTIONS][FractionInfo];

Что тут может быть не так?))

Share this post


Link to post
Share on other sites

@DaGroIII Фракция же не одна в БД, а множество, поэтому необходим цикл: 

stock LoadFraction()
{
  mysql_query(Database, "SELECT * FROM `Fraction`");
  new row_count; 
  cache_get_row_count(row_count); 
  for (new i = 0; i < row_count; i++)
  {
    cache_get_value_name_int(i, "ID", fInfo[i][ID]);
    cache_get_value_name(i, "Name", fInfo[i][Name]);
    ...
  }
}

 

Share this post


Link to post
Share on other sites

@DEST Все отлично, ошибок не стало :) Но вот не хочет отображать текст..

cmd:test(playerid)
{
	if(pInfo[playerid][Member] == 1)
	{
	    new fID = pInfo[playerid][Member];
		static const fmt_str[] = "Вы состоите в Организации - %s";
		new string[sizeof(fmt_str)+5];
		format(string, sizeof(string), fmt_str, fInfo[fID][Name]);
		SCM(playerid, COLOR_RED, string);
	}

}

Хочу вывести игроку, который состоит в фракции под ID 1, название его фракции

Edited by DaGroIII

Share this post


Link to post
Share on other sites

@DaGroIII Для каждой новой проблемы создавайте новую тему. Если эта проблема, которая обозначена в заголовке, решена, то отметьте галочкой сбоку ответ, который является решением и создайте новую тему. 

Share this post


Link to post
Share on other sites
Guest
This topic is now closed to further replies.
Sign in to follow this  
Followers 0

  • Recently Browsing   0 members

    No registered users viewing this page.

  • Similar Content

    • Novaro.Vaiper
      By Novaro.Vaiper
      Приветствую.

      Условия:

      - Если вы надежный человек
      - Можете выходить на связь [Говорить, скайп дискорд.]
      - Если вы продуктивный и пунктуальный

      Обязанности:
      - Просто написать мод с нуля. [Естественно для начала просто под основу. На Основе самый новых и полезных плагинов которые могут быть]
      - Мы должны с вами сообщиться, понравится друг другу в делом подходе к нашему делу. То есть мы должны вызывать самое главное, доверие друг у друга.

      К слову.


      Безусловно большим плюсом в нашей с вами кампании будет ваше портфолио проделанной работы.
      Мы можем найди вам помощника. Одна голова хорошо, а две еще лучше!
      Естественно оплата будет оплачена после работы. Примечание, выплата может быть осуществлена два раза в месяц. Горы не обещаю конечно, для начала поработаем. На первое время помогу материально в случае прогресса развития мода.
      На момент работы будут оплачен хостинг самого сервера, для того, что бы мы могли еще с вами тестировать наш с вами сервер.
      Что входит под сленгам "Под основу" Я хочу видеть:
      Регистрацию: Тз есть
      Фракции: Тз будет ! 

      Работа есть!
      Пишите по делу! https://vk.com/sailencer
    • KAIF
      By KAIF


      Просмотр файла [0.3.7]GTA RolePlay-
      Здравствуйте, хотел бы продать переделанный игровой мод всем знакомого проекта GTA RolePlay
      Фракции:
      1)Правительство
      2)ГИБДД
      3)Полиция Южного
      4)ФСБ
      5)ЦГБ-А
      6)Автошкола
      7)ВВС
      8)СМИ
      9)ОМОН
      10)опг.Тукаевские
      11)опг.Тяп-Ляп
      12)Чеченская Мафия
      13)Американская Мафия
      14)Якудза
      15)Русская Мафия
      16)Итальянская Мафия
      Добавлено/исправлено:
      1)Добавлен ВЕСЬ ОПТИМИЗИРОВАННЫЙ маппинг GTA ROLEPLAY.(2018-2019г)
      2)Добавлены организации мафий.
      3)Перенесены все чекпоинты как на GTA ROLEPLAY.
      4)Добавил в донат покупку военного билета.
      5)Изменил название рангов во фракциях как на GTA ROLEPLAY/
      6)Изменен логотип GTA ROLEPLAY
      7)Переделан весь GPS, изменены все координаты.
      В моде - 6 уровней администрации.(если хотите можете увелить кол-во админок)
      Имеется фуллдоступ, выдаётся в pawno.
      Так же в комплекте будет идти мод-пак к серверу.
      После покупки вы получите архив с модом, а в самом архиве будет текстовый файл с ссылкой на скачивание модпака.
      Добавил KAIF Добавлено 27.12.2020 Категория Моды Автор Kytip  
    • danya1102
      By danya1102
      я хочу запустить локальный сервер, но с ним что-то
      вот лог
       
      server_log.txt