Вопросы

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

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

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


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

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


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

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

  • 0

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

new fractionId = pInfo[playerid][fID];

fInfo[fractionId][...]

 

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


Ссылка на сообщение
  • 0
В 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 ), то игроку выводило бы сообщение Вы состоите в Организации - ( допустим ) ЛСПД. 

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

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


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

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

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


Ссылка на сообщение
  • 0
14 минут назад, DEST сказал:

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

new fInfo[FractionInfo]

Если сделать

new fInfo[MAX_PLAYERS]

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

 

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

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


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

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

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

 

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


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

@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];

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

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


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

@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]);
    ...
  }
}

 

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


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

@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, название его фракции

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

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


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

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

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


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

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

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

    • Доналдо Фарекелка
      От Доналдо Фарекелка


      Скачать файл Arizona RolePlay || Ser
      Приветствую, этот мод я нашёл на просторах интернета. 
      Скачал мод у автора:  Developer Stravinskiy
      Доработал мод: Donaldo_Farekelka
       
      Предупреждаю! Мод сырой, багов стало меньше, но они есть.
      Мод: Баня, Подвал, В некоторых местах маппинг, система коронавируса, 8 лвл админок
       
      Информация:
      1) Dc_Cmd
      2) Mysql, mode, language - Всё настраивается теперь в pawno ( UPDATE: 1.1.0 )
      3) Административные права в данный момент можно выдать только через MYSQL ( BD ).
       
      То что я сделал ( Всё что я делаю сейчас, смотрите в изменениях ):
       
      Добавил Доналдо Фарекелка Добавлено 13.04.2023 Категория Моды Автор shenol (vk.com/donaldo_farekelka)  
    • KAIF
      От KAIF


      Скачать файл GTA RolePlay-МОД,СБОРКА
      !!!!!ВСЕГО ОДНА КОПИЯ!!!! 
      Единственный мод GTA RP.
       
      Фракции:
      Правительство
      ГИБДД
      Полиция Южного
      ФСБ
      ЦГБ-А
      Автошкола
      Китайская мафия
      Русская Мафия
      Итальянская Мафия
      Американская Мафия
      Чеченская Мафия
      ВВС
      МЧС
      ОПГ Тяп-Ляп
      ОПГ Хади-Такташ
      СМИ Южного
      ФСИН
      В комплекте идёт СБОРКА И МОД.
      Единственный мод GTA RP.
      Добавил KAIF Добавлено 01.01.2024 Категория Моды Автор Aleksandr  
    • gooding
      От gooding
      Доброго времени суток! Я выложил на продажу игровой мод RedRow RolePlay!
       
      17 ТИТУЛОВ, 14 КОСТЮМОВ (КАМЕРМЭН, ФЕЯ, СИ-ДЖЕЙ, ДЭДПУЛ, СПАНЧ БОБ, НИНДЗЯ, ДЕД МОРОЗ и другие!),
      BMW I8, BMW M5, BMW Vision M NEXT, Mercedes-Benz G-CLASS, Rolls-Royce Phantom! Система рулетки  (Исправлена, теперь не выпадает одно и то же),
      Автопарки Фракций (FBI и банд), МОД ОПТИМИЗИРОВАЛИ под ИГРУ, ДОБАВИЛИ НОВЫЙ АНТИЧИТ (Latest Nex-AC) и АНТИЧИТ настроен. Проделано много работы (Над модом работали полгода) и исправили множество багов.
       
      Что было добавлено?
      1. 17 титулов,
      2. 14 костюмов,
      3. Эксклюзивный транспорт (SandKing, Rolls-Royce Phantom, BMW I8, BMW M5, BMW Vision M NEXT, Mercedes-Benz G-CLASS).
      4. Автопарк ФБР и всех банд.
      5. Новый анти-чит.
      6. Оптимизация игрового мода.
      7. Премиум и уникальные возможности для владельцев Премиума.
      8. Команда /bonus, где можно получить бесплатно Red Coins.
      9. За АКТИВ даются Red Coins!
      10. Рестарт сервера в 5:00 по МСК.
      11. Радужный клист.
      12. Уникальный тюнинг для эксклюзивных машин и ускорение.
      13. Новая система банка.
      14. Исправлено множество багов.
      15. Новый маппинг.
    • Redmondd
      От Redmondd
      Хочу сделать команду /gpsoff, которая убирает метку