質問編集履歴

1 誤字修正しました

maifukuhara

maifukuhara score 58

2017/01/27 17:52  投稿

cakephp3、FriendsOfCake/Serchプラグインで、concatで文字結合したフィールドを検索したい
cakephp3、FriendsOfCake/Searchプラグインで、concatで文字結合したフィールドを検索したい
cakephp3で顧客テーブルをfriendsofcake/serchで検索する部分を開発しています。
cakephp3で顧客テーブルをfriendsofcake/Searchで検索する部分を開発しています。
このテーブルで、住所1、2を文字列結合して検索したいです。
![イメージ説明](71e50180b0453083ea59005ade007cd3.gif)
最終的に発行したいSQLは下記の様になるかと思います。
```SQL
select * from customers where concat(address_1, address_2) LIKE '%word(検索文字列)%'
select * from customers where concat(address_1, address_2) LIKE '%words(検索文字列)%'
```
cakephp2.xでは、仮想フィールド(virtualfield) を使い
「full_address」等の名前でconcatしたフィールドを設定しておけば
検索クエリでも、そのまま使えたらしいのですが、
cakephp3.xからは、下記理由のためできなくなったようです。
[http://palmgate.co.jp/masato_kato/article.html&id=164](http://palmgate.co.jp/masato_kato/article.html&id=164)
他画面を「firiendsofcake/searchプラグイン」を使って
開発を進めてきたため、できればプラグインを使ったまま対応したいです。
下記の記事を見つけましたが、cakephp3そのものの
経験が浅く、思うようなクエリを発行してくれません
[http://stackoverflow.com/questions/37333873/concat-fields-in-search-plugin-cakephp-3
](http://stackoverflow.com/questions/37333873/concat-fields-in-search-plugin-cakephp-3)
アドバイスをお願いできないでしょうか。
よろしくお願いします。
↓ C:\xampp\htdocs\cake3\src\Template\Customers\index.ctp
```php
echo $this->Form->create();
echo $this->Form->input('id');  //idを入力
echo $this->Form->input('words'); //住所を入力
echo $this->Form->button("送信", ['type' => 'submit']);
echo $this->Form->end();
debug($customers);
```
↓ C:\xampp\htdocs\cake3\src\Model\Table\CustomersTable.php
```php
use Search\Manager;  //Searchプラグイン用
class CustomersTable extends Table
{
   public function initialize(array $config)
   {
     parent::initialize($config);
      /* Searchプラグイン用 */
      $this->addBehavior('Search.Search');
      $this->searchManager()
         ->value('id')
         ->add('words', 'Search.Like', [
               'before' => true,
               'after' => true,
               'fieldMode' => 'OR',
               'comparison' => 'LIKE',
               'wildcardAny' => '*',
               'wildcardOne' => '?',
       //試したこと1 仮想フィールドを指定・・・ダメ
       //        'field' => 'full_address'
       //試したこと2 concatを直接書く・・・ダメ
       // こんなSQLになる→  WHERE  Customers.concat(address_1, address_2) like '%words%'
       //        'field' => 'concat(address_1, address_2)'
       //   ]);
//試したこと3 下記を見て、コールバックを設定してみる
//http://stackoverflow.com/questions/37333873/concat-fields-in-search-plugin-cakephp-3
   ->add('word', 'Search.Callback', [
   'callback' => function ($query, $args, $manager) {
   return $query->select([
                  'full_address' => $query->func()->concat([
                   'address_1' => 'identifier',
                   'address_2' => 'identifier'
                    ])
                 ])
                 ->having(['full_address LIKE' => '%' . $args['words'] . '%']);
     }
       ]);
以下略
```
仮想フィールドは上手くいきませんでしたが、こんなかんじで書きました。
↓C:\xampp\htdocs\cake3\src\Model\Entity\Customer.php
```PHP
class Customer extends Entity
{
   protected $_virtual = [
       'full_address',
   ];
   protected function _getFullAddress()
   {
       return $this->_properties['address_1'].
              $this->_properties['address_2'];
   }
 :
以下略
```     
↓C:\xampp\htdocs\cake3\src\src\Controller\CustomersController.php
```PHP
class CustomersController extends AppController
{
    public function initialize()
    {
      parent::initialize();
      //サーチプラグインの読み込み
      $this->loadComponent('Search.Prg', [
        'actions' => ['index']
      ]);
    }
   public function index()
   {
   $selected = $this->Customers
     ->find('search', ['search' => $this->request->query])
   $this->set('customers', $this->paginate($selected));
 :
以下略
```
■参考にしたもの
http://stackoverflow.com/questions/37333873/concat-fields-in-search-plugin-cakephp-3
http://www.naidim.org/cakephp-3-tutorial-11-virtual-fields
  • PHP

    11084questions

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

  • CakePHP

    1479questions

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

  • Framework

    63questions

    Frameworkは、アプリケーションソフトを開発する際に、一般的な機能をより簡単に、より早く完了させる事を目的とした、ソフトウェアやライブラリのセットを指します。開発にフレームワークを使用する事で、追加で必要となる機能だけを開発するだけで済む為、開発効率の向上が見込めます。

思考するエンジニアのためのQ&Aサイト「teratail」について詳しく知る