Модераторы: skyboy, MoLeX, Aliance, ksnk

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> сгенерировать форму из таблицы 
:(
    Опции темы
lifox
Дата 17.5.2008, 15:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 12
Регистрация: 17.5.2008

Репутация: нет
Всего: нет



Доброго всем дня.

У меня есть страницы где должно сгенерироваться формы и есть таблицы

`jeep`
id int
model varchar(45)
god varchar(45)
categor varchar(45)

`ferrari`
id int
model varchar(45)
god varchar(45)
categor varchar(45)

как сгенерировать ссылку из имени таблицы а по этой ссылке формы model varchar(45)
                                                                                                                  god varchar(45) для заполнение
т.е. на странице должна сгенерироваться ссылка `jeep` при нажатие на нее генерируется формы и если категория внедорожники то генериуется только категории внедорожники
PM MAIL   Вверх
Fortop
Дата 17.5.2008, 17:56 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2200
Регистрация: 13.11.2007
Где: Донецк

Репутация: 3
Всего: 42



1. Все свои джипы и феррари храни в одной таблице.

Код

auto
id int
modelname varchar(45) // вот тут все твои джипы и прочее
modelno varchar(45)
god varchar(45)
categor varchar(45)


2.
Код

select distinct modelname from auto

Все виды марок автомобилей

ну а уж ссылки из этого массива построить - вообще задача тривиальная
Код

echo '<ul>';
foreach ($modelnames as $val) {
    echo '<li><a href="/site/' . $val . '">' . $val . '</a></li>';
}
echo '</ul>';




--------------------
Мир это Я.
Живее всех живых.
PM MAIL   Вверх
lifox
Дата 18.5.2008, 06:43 (ссылка)    | (голосов:2) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 12
Регистрация: 17.5.2008

Репутация: нет
Всего: нет



Возможно если будет таблица  `all_mashine`  и  делая выборку  из нее по table_name делать ссылки и при нажатие на нее будет генерироваится формы 

`all_mashine`
id int
table_name varchar(45)
categor varchar(45)


`jeep`
id int
model varchar(45)
god varchar(45)

`ferrari`
id int
model varchar(45)
god varchar(45)
PM MAIL   Вверх
MoLeX
Дата 18.5.2008, 07:34 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Местный пингвин
****


Профиль
Группа: Модератор
Сообщений: 4076
Регистрация: 17.5.2007

Репутация: 7
Всего: 140



lifox, зачем тебе столько таблиц? пихай все в одну + индификаторы для машин используй. 


--------------------
Amazing  smile 
PM MAIL WWW ICQ   Вверх
lifox
Дата 18.5.2008, 08:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 12
Регистрация: 17.5.2008

Репутация: нет
Всего: нет



У таблиц будут разное количество поле
PM MAIL   Вверх
MoLeX
Дата 18.5.2008, 08:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Местный пингвин
****


Профиль
Группа: Модератор
Сообщений: 4076
Регистрация: 17.5.2007

Репутация: 7
Всего: 140



Цитата(lifox @  18.5.2008,  08:10 Найти цитируемый пост)
У таблиц будут разное количество поле

это почему же? ну даже и разное. допустим максимальное их будет 9, ферари займет 6, джип все 9. т.е. при выводи смотришь - аха такие-то поля пустые (NULL возратил запрос) значит их не надо трогать


--------------------
Amazing  smile 
PM MAIL WWW ICQ   Вверх
lifox
Дата 18.5.2008, 09:06 (ссылка)    | (голосов:2) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 12
Регистрация: 17.5.2008

Репутация: нет
Всего: нет



у меня на сайте эти таблицы генерируются  каждая по отдельности и мне лучше будет сделать так. 

`all_mashine`
id int
table_name varchar(45)
categor varchar(45)


`jeep`
id int
model varchar(45)
god varchar(45)

`ferrari`
id int
model varchar(45)
god varchar(45) 

а сама задача состоит в том чтобы  на странице должна сгенерироваться ссылка `jeep`при выборке из таблицы `all_mashine` при нажатие на нее генерируется формы и если категория = внедорожники то генериуется только категории внедорожники.

И как мне  сделать эту выборку 

Это сообщение отредактировал(а) lifox - 18.5.2008, 09:33
PM MAIL   Вверх
Fortop
Дата 18.5.2008, 11:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2200
Регистрация: 13.11.2007
Где: Донецк

Репутация: 3
Всего: 42



lifox
Сколько, говоришь,  у тебя будет видов машин?

Понимаешь ли, если все это будет в одной таблице, то и запрос будет всего 1. С немного разными условиями.
В твоем же случае, запрос прийдется писать на каждую таблицу.

Более того логика построения БД такова, что одинаковые сущности (т.е. машины) должны все храниться в одной таблице.

Применительно к той таблице, что я давал

Все джипы
Код

SELECT * FROM auto WHERE modelname = 'jeep'


Все внедорожники. (и не важно Jeep, Nissan, Toyota) - будут выбраны именно все внедорожники.
Код

SELECT * FROM auto WHERE category = 'offroad'


Все внедорожники марки Jeep
Код

SELECT * FROM auto WHERE modelname = 'jeep' AND category = 'offroad'


А вот в твоем случае нужен будет такой же запрос только для каждой марки авто в отдельности...

Добавлено через 1 минуту и 33 секунды
lifox, и вообще, с каких делов у тебя Ferrari и Jeep должны иметь разное количество полей?
Это тоже вопрос решаемый.

Но ты объясни, почему у них должна быть разная структура?


--------------------
Мир это Я.
Живее всех живых.
PM MAIL   Вверх
lifox
Дата 18.5.2008, 11:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 12
Регистрация: 17.5.2008

Репутация: нет
Всего: нет



У меня таблицы автомобилей герерируются из XML файла, а файлы я получаю от разных людей и структура у них может быть разная. Стандарт начальный   id int
                                                                                                  model varchar(45)
                                                                                                  god varchar(45)  
В одном файле может быть и поле цвета машины а в другом файле его и не добавят 
PM MAIL   Вверх
lifox
Дата 18.5.2008, 11:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 12
Регистрация: 17.5.2008

Репутация: нет
Всего: нет



Хорошо тогда как можно сгенирировать формы из таблицы 

`jeep`
id int
model varchar(45)
god varchar(45)

PM MAIL   Вверх
Feldmarschall
Дата 18.5.2008, 12:32 (ссылка) |    (голосов:2) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок
****


Профиль
Группа: Участник
Сообщений: 2641
Регистрация: 11.12.2007

Репутация: 1
Всего: 32



Жесть какая.
У тебя все неправильно спроектировано в принципе.
Структура БД - это не та часть сайта, которой занимаются всякие левые сейлсы, присылая свои кривые файлы. 

PM   Вверх
Fortop
Дата 18.5.2008, 12:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2200
Регистрация: 13.11.2007
Где: Донецк

Репутация: 3
Всего: 42



lifox
1. Спили мушку smile
2. Уточни, что именно у тебя не получается при генерации формы smile

Добавлено через 2 минуты и 27 секунд
lifox
Цитата(lifox @  18.5.2008,  11:41 Найти цитируемый пост)
В одном файле может быть и поле цвета машины а в другом файле его и не добавят  

Ну не добавили, значит не добавили. 

INSERT INTO auto (fieldname1, fieldname2,...., fieldnameN) VALUES (value1, value2, ...., valueN)

Нет какого-то поля просто убирается пара fieldname - value.
И все будет работать нормально с одной и той же таблицей.


--------------------
Мир это Я.
Живее всех живых.
PM MAIL   Вверх
lifox
Дата 19.5.2008, 16:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 12
Регистрация: 17.5.2008

Репутация: нет
Всего: нет



Цитата(Fortop @ 18.5.2008,  12:38)
2. Уточни, что именно у тебя не получается при генерации формы smile


Как сгенирировать саму форму
PM MAIL   Вверх
Fortop
Дата 19.5.2008, 22:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2200
Регистрация: 13.11.2007
Где: Донецк

Репутация: 3
Всего: 42



lifox
Код

$data = mysql_fetch_assoc($result);

echo '<form name="somename" action="someaction.php" method="post">';
foreach ($data as $key => $val) {
    echo '<label for="' . $key . '">' . $key . '</label>';
    echo '<input type="text" name="' . $key . '" id="' . $key . '" value="' . htmlspecialchars($val,  ENT_QUOTES) . '">';
}
echo '</form>';

Вот и вся форма


--------------------
Мир это Я.
Живее всех живых.
PM MAIL   Вверх
lifox
Дата 27.5.2008, 17:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 12
Регистрация: 17.5.2008

Репутация: нет
Всего: нет



Цитата(Fortop @ 18.5.2008,  11:19)
Понимаешь ли, если все это будет в одной таблице, то и запрос будет всего 1. С немного разными условиями.
В твоем же случае, запрос прийдется писать на каждую таблицу.


почему же, есть таблица 

`all_mashine`
id int
table_name varchar(45)
categor varchar(45)

нужно написать на нее один запрос
PM MAIL   Вверх
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | PHP: Базы Данных | Следующая тема »


 




[ Время генерации скрипта: 0.0868 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.