У меня есть форма, которая передает данные в базу данных в приложении Codeigniter (Ci v. 2.0.2). Мы позволяем пользователям «редактировать» записи, заставляя их повторно повторно записать с новыми значениями, а затем сделать обновление. При отправке форма вызывает метод создания контроллера голосования. Внутри метода создания мы проверяем, есть ли уже запись на основе кода входа и идентификатора пользователя. Если есть, мы обновляем; В противном случае мы создаем новую запись. Сотворение работает просто отлично; Это только то обновление, с которым у меня есть проблема. Вот код. < /P>
view < /strong> < /p>
Entry code:
Question 1:
Question 2:
Question 3:
Question 4:
Question 5:
< /code>
контроллер < /strong> < /p>
function create() {
$id = $this->input->post('entry_code');
$judge_id = $this->input->post('dot_judge_id');
$data = array(
'entry_code' => $id,
'dot_judge_id' => $judge_id,
'q1' => $this->input->post('q1'),
'q2' => $this->input->post('q2'),
'q3' => $this->input->post('q3'),
'q4' => $this->input->post('q4'),
'q5' => $this->input->post('q5'),
);
//first check to see if there's already a record for this judge/entry
//if so, update. Otherwise, insert
$vote_id = $this->vote_model->getEntryById($id, $judge_id);
if($vote_id) {
log_message('debug', 'vote id exists: '.$vote_id);
$this->vote_model->updateRecord($data, $vote_id);
}
else {
log_message('debug', 'vote id does not exist; creating new');
$this->vote_model->createRecord($data);
}
/*
after submission, go to another page that gives choices - review entries, submit another entry, log out
*/
$data['msg'] = "Entry submitted";
$this->menu();
}
< /code>
model < /strong> < /p>
function getEntryByID($id, $judge_id) {
//determine if record already exists for entry/judge
$sql = 'SELECT vote_id from dot_vote WHERE entry_code = ? AND dot_judge_id = ?';
$query = $this->db->query($sql, array($id, $judge_id));
if($query->num_rows() == 1) {
$row = $query->row();
return $row->vote_id;
}
else {
return false;
}
}
function createRecord($data) {
$this->db->insert('dot_vote', $data);
return;
}
function updateRecord($data, $vote_id) {
log_message('debug', 'vote id is passed: '.$vote_id);
$this->db->where('vote_id', $vote_id);
$this->update('dot_vote', $data);
}
< /code>
Я знаю, что он попадает в метод UpdatereCord, потому что выход Log_message находится в моем файле журнала, отображающего правильный hoge_id (поле автоматического инкромента возвращенной записи). Но то, что я получаю в браузере, является следующим: < /p>
< /p>
может указать меня в правильном направлении здесь? У меня есть ошибка отображения в моем файле конфигурации, и я получил ошибки SQL, когда они возникают, поэтому я не думаю, что это ошибка SQL. Но я понятия не имею, что может произойти в той крошечной функции, которая вызывает это. Мой следующий шаг - пропустить обновление активной записи и просто использовать стандартный запрос, но я хотел бы знать, что вызывает проблему здесь, даже если я могу заставить его работать в другую сторону.
Подробнее здесь: https://stackoverflow.com/questions/658 ... odeigniter
Проблема с активным обновлением записей в Codeigniter [закрыто] ⇐ Php
Кемеровские программисты php общаются здесь
-
Anonymous
1755993910
Anonymous
У меня есть форма, которая передает данные в базу данных в приложении Codeigniter (Ci v. 2.0.2). Мы позволяем пользователям «редактировать» записи, заставляя их повторно повторно записать с новыми значениями, а затем сделать обновление. При отправке форма вызывает метод создания контроллера голосования. Внутри метода создания мы проверяем, есть ли уже запись на основе кода входа и идентификатора пользователя. Если есть, мы обновляем; В противном случае мы создаем новую запись. Сотворение работает просто отлично; Это только то обновление, с которым у меня есть проблема. Вот код. < /P>
view < /strong> < /p>
Entry code:
Question 1:
Question 2:
Question 3:
Question 4:
Question 5:
< /code>
контроллер < /strong> < /p>
function create() {
$id = $this->input->post('entry_code');
$judge_id = $this->input->post('dot_judge_id');
$data = array(
'entry_code' => $id,
'dot_judge_id' => $judge_id,
'q1' => $this->input->post('q1'),
'q2' => $this->input->post('q2'),
'q3' => $this->input->post('q3'),
'q4' => $this->input->post('q4'),
'q5' => $this->input->post('q5'),
);
//first check to see if there's already a record for this judge/entry
//if so, update. Otherwise, insert
$vote_id = $this->vote_model->getEntryById($id, $judge_id);
if($vote_id) {
log_message('debug', 'vote id exists: '.$vote_id);
$this->vote_model->updateRecord($data, $vote_id);
}
else {
log_message('debug', 'vote id does not exist; creating new');
$this->vote_model->createRecord($data);
}
/*
after submission, go to another page that gives choices - review entries, submit another entry, log out
*/
$data['msg'] = "Entry submitted";
$this->menu();
}
< /code>
model < /strong> < /p>
function getEntryByID($id, $judge_id) {
//determine if record already exists for entry/judge
$sql = 'SELECT vote_id from dot_vote WHERE entry_code = ? AND dot_judge_id = ?';
$query = $this->db->query($sql, array($id, $judge_id));
if($query->num_rows() == 1) {
$row = $query->row();
return $row->vote_id;
}
else {
return false;
}
}
function createRecord($data) {
$this->db->insert('dot_vote', $data);
return;
}
function updateRecord($data, $vote_id) {
log_message('debug', 'vote id is passed: '.$vote_id);
$this->db->where('vote_id', $vote_id);
$this->update('dot_vote', $data);
}
< /code>
Я знаю, что он попадает в метод UpdatereCord, потому что выход Log_message находится в моем файле журнала, отображающего правильный hoge_id (поле автоматического инкромента возвращенной записи). Но то, что я получаю в браузере, является следующим: < /p>
< /p>
может указать меня в правильном направлении здесь? У меня есть ошибка отображения в моем файле конфигурации, и я получил ошибки SQL, когда они возникают, поэтому я не думаю, что это ошибка SQL. Но я понятия не имею, что может произойти в той крошечной функции, которая вызывает это. Мой следующий шаг - пропустить обновление активной записи и просто использовать стандартный запрос, но я хотел бы знать, что вызывает проблему здесь, даже если я могу заставить его работать в другую сторону.
Подробнее здесь: [url]https://stackoverflow.com/questions/6588781/issue-with-active-record-update-in-codeigniter[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия