Jump to content
  • 0

Отправка данных из одной формы в разные БД


slavok47
 Share

Question

Собственно с одной проблемой разобрался в этой теме http://forum.htmlbook.ru/index.php?showtopic=16079

там продолжать не стал, т.к вопрос о другом хотя и связан с темой выше,

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

есть одно условие эта функция должна выполняться на стороне клиента, так как форма на хостинге который не поддерживает PHP,

соответственно путь к обработчику выглядит так

<form  action="http://адрес/insert.php" method="post"  name="form" onReset="setDefaults(this);">

Link to comment
Share on other sites

14 answers to this question

Recommended Posts

  • 0

а собственно в чём ваши затруднения ? делайте разбор формы в другом месте (http://адрес/insert.php), этим же скриптом в зависимости от выбранного поля в форме делайте разные действия

Link to comment
Share on other sites

  • 0
а собственно в чём ваши затруднения ? делайте разбор формы в другом месте (http://адрес/insert.php), этим же скриптом в зависимости от выбранного поля в форме делайте разные действия

Чет не понял, сделать несколько обработчиков и в массив загнать адреса к ним? или как?

Link to comment
Share on other sites

  • 0

Проблема в том, чтобы выбрать, к какой базе подключиться? А как это можно вообще сделать на стороне клиента в нынешней реализации HTML? o_O

Или нужно менять обработчик формы в зависимости от параметров? Ну можно сделать один универсальный, который потом перенаправляет куда нужно.

Edited by Int
Link to comment
Share on other sites

  • 0

slavok47,

если код скрипта остался таким как на http://forum.htmlbook.ru/index.php?showtopic=16079

могу предложить такое решение:

<script type="text/javascript">	
var servdb = new Object()
servdb["data1"] = [{value:"1", text:"Пример 1", url:"url1"},
{value:"2", text:"Пример 2", url:"url2"},
{value:"3", text:"Пример 3", url:"url3"},
{value:"4", text:"Пример 4", url:"url4"}];
servdb["data2"] = [{value:"1", text:"Пример 5", url:"url5"},
{value:"2", text:"Пример 6", url:"url6"},
{value:"3", text:"Пример 7", url:"url7"},
{value:"4", text:"Пример 8", url:"url8"},
{value:"5", text:"Пример 9", url:"url9"}];

function settest(chooser) {
var dataChooser = chooser.form.elements["sel2"];
dataChooser.options.length = 0;
var choice = chooser.options[chooser.selectedIndex].value;
var db = servdb[choice];
dataChooser.options[0] = new Option("Примеры ", "", true, false);
if (choice != "") {
for (var i = 0; i < db.length; i++) {
dataChooser.options[i + 1] = new Option(db[i].text, db[i].value);
}
}
}
function setaction (chooser, sel2)
{
var choice = chooser.options[chooser.selectedIndex].value;
var db = servdb[choice];
document.primer.action=db[sel2.value-1].url;
}
</script>
</head>
<body>
<form name="primer" action="">
<select name="test" onchange="settest(this)">
<option value="" selected>Выбор сервера</option>
<option value="data1">Сервер 1</option>
<option value="data2">Сервер 2</option>
</select>
<select name="sel2" onchange="setaction(test, this)">
<option value="" selected>Примеры</option>
</select>
<input type="submit" name="" />
</form>

Link to comment
Share on other sites

  • 0

Если я правильно понял то эти части

[{value:"1", text:"Пример 1", url:"url1"},

должны выглядеть например как

[{value:"1", text:"Пример 1", url:"http://адрес/insert.php"},

тоесть прописываться пути к обработчикам

Или нет?

Edited by slavok47
Link to comment
Share on other sites

  • 0

Да, именно так.

Соответственно, по тем урлам должны быть php-скрипты обработчики вашей формы.

Еще вам нужно указать метод передачи данных из формы:

method="post" или method="get"

выбор метода зависит от скриптов-обработчиков.

Edited by Flare
Link to comment
Share on other sites

  • 0

А можно на стороне сервера:

switch($_POST['base'])
{
case 1: {$base=mysql_connect('server1','',''); break;}
case 2: {$base=mysql_connect('server2','',''); break;}
case 3: {$base=mysql_connect('server3','',''); break;}
case 4: {$base=mysql_connect('server4','',''); break;}
}

Edited by Int
Link to comment
Share on other sites

  • 0

Я читал. В 4-м HTML на стороне клиента нельзя подключиться к базе данных.

Автор сам в action указал php-скрипт, значит всё-таки где-то этот php имеется.

Edited by Int
Link to comment
Share on other sites

  • 0

Кстати Flare, спасибо за помощь вроде работает, подробно правда еще не проверял....

а вот метод Int конечно лучше было бы, сделать универсальный обработчик но только я что то не понял ни чего :) и сработает ли он в моем случае, а так придется делать 12 обработчиков B)

Link to comment
Share on other sites

  • 0

Да что ж непонятного? Скрипт получает номер базы, к которой нужно плюключиться, подключается. В итогде имеется идентификатор подключения, с которым ты дальше и работаешь. Если где-то дальше нужно учитывать, к какой базе прошло подключение, значит нужно ещё и этот параметр записать где-нибудь.

Edited by Int
Link to comment
Share on other sites

  • 0
Да что ж непонятного? Скрипт получает номер базы, к которой нужно плюключиться, подключается. В итогде имеется идентификатор подключения, с которым ты дальше и работаешь. Если где-то дальше нужно учитывать, к какой базе прошло подключение, значит нужно ещё и этот параметр записать где-нибудь.

Все правильно.

slavok47, похоже вы сами не знаете, чего хотите.

Сначала вы говорите, что у вас сколько элементов в списке, столько и баз данных.

Потом вы говорите, что не хотите 12 обработчиков иметь, но ваш хостинг не поддерживает php и, следовательно, нельзя сделать один обработчик, который будет сам рассылать данные в нужную базу.

Вы сначала определитесь с задачей, а потом уже задавайте вопросы.

Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Answer this question...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

 Share

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue. See more about our Guidelines and Privacy Policy