質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

Q&A

解決済

1回答

395閲覧

データベースに登録するとき、idと同じ値を別のカラムにも登録したい

harukuri

総合スコア21

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

0グッド

0クリップ

投稿2022/02/20 11:37

実現したいこと

PHP(CakePHP2)でカテゴリー一覧を表示するページを作っています。
カテゴリー名の横のボタンを押すと、クリックすると行の上下が移動するようにしたいです。

まず、カテゴリー新規追加ページから、カテゴリー名を登録したとき、
表示順は入力しなくても
表示順をしめすorder_numberというカラムにidと同じ値が登録されるようにしたいです。
どのようにしたらいいか教えていただけないでしょうか。

テーブル名:categories
| id | category_name | order_number |
| 1 | カテゴリー1 | 1 |
| 2 | カテゴリー2 | 2 |
| 3 | カテゴリー3 | 3 |
このようにしたいです。

テーブル定義

CREATE TABLE `sample` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT, `name` varchar(16) DEFAULT NULL, `order_number` int(11) DEFAULT NULL, PRIMARY KEY (`id`) )

該当のソースコード

Cakephp2 add.ctp

1<?php 2echo $this->Form->create('Category',array('novalidate' => true)); 3echo $this->Form->input('id'); 4echo $this->Form->input('category_name'); 5echo $this->Form->end('登録'); 6?>

試したこと

https://blog.s-giken.net/100.html
上記のページを参考にして、
コントローラーにidの値が送られ保存された後、idを取得して
order_numberに保存するようにすればいいのではないかと考えました。
しかし、下記のようにすると

例えばカテゴリー3を登録した場合、
| id | category_name | order_number |
| 1 | カテゴリー3 | NULL |
| 2 | NULL | NULL |
というようにカテゴリー名以外は値が入りませんでした。

Cakephp2 CategoriesController.php

1public function add(){ 2 3 if($this->request->is('post')){ 4 if($this->Category->save($this->request->data)){ 5 $id = $this->request->data('id'); 6 $options = array('conditions' =>array('Category.id' =>$id)); 7 $save_array = array('id' =>$id, 8 'order_number' => $id); 9 $this->Category->save($save_array); 10 $this->Session->setFlash('登録されました'); 11 return $this->redirect(array('action' => 'index')); 12 } 13 } 14 }

・add.ctpに

echo $this->Form->hidden('order_number',array('value'=>$category['Category']['id']));

といれることも考えたのですが、上手くいきませんでした。
よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

takasima20

2022/02/20 12:01

トリガーでやったら?
guest

回答1

0

自己解決

新規登録したとき、idと同じ値を別のカラムにも登録するという操作です。

新規登録時は、登録された後でないとidは分からないため、
コントローラーで最後に登録したidを取得して、order_number を更新することにしました。
getLastInsertID()について以下のページを参考にしました。
http://www.php-mysql-linux.com/cake-php/last-insert-data-no/

CakePHP2

1 public function add() 2 { 3 if ($this->request->is('post')) { 4 if ($this->Category->save($this->request->data)) { 5 $lastID = $this->Category->getLastInsertID(); 6 $this->Category->id = $lastID; 7 $this->Category->saveField('order_number',$lastID); 8 9 } 10 } 11 }

投稿2022/02/21 12:49

harukuri

総合スコア21

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問