ricevo una soluzione del mio problema. E sta funzionando bene. Si prega di fare riferimento al codice sottostante e commentare se ho torto in qualsiasi luogo.
->app.php
'Datasources' => [
'default' => [
'className' => 'Cake\Database\Connection',
'driver' => 'Cake\Database\Driver\Mysql',
'persistent' => false,
'host' => 'localhost',
//'port' => 'nonstandard_port_number',
'username' => 'your_username',
'password' => 'your_password',
'database' => 'tracking_system', // This is my default database
'encoding' => 'utf8',
'timezone' => 'UTC',
'cacheMetadata' => true,
'quoteIdentifiers' => false,
//'init' => ['SET GLOBAL innodb_stats_on_metadata = 0'],
],
'db2' => [
'className' => 'Cake\Database\Connection',
'driver' => 'Cake\Database\Driver\Mysql',
'persistent' => false,
'host' => 'localhost',
//'port' => 'nonstandard_port_number',
'username' => 'your_username',
'password' => 'your_password',
'database' => 'tracking_system2', // This is my second database
'encoding' => 'utf8',
'timezone' => 'UTC',
'cacheMetadata' => true,
'quoteIdentifiers' => false,
//'init' => ['SET GLOBAL innodb_stats_on_metadata = 0'],
]
]
->TodolistsController.php
database name: tracking_system2
table name: todolists
- aggiungere questa linea al vostro controller
utilizzare Cake \ Datasource \ ConnectionManager;
mio codice TodolistsController.php è:
<?php
namespace App\Controller;
use App\Controller\AppController;
use Cake\ORM\TableRegistry;
use Cake\ORM\Entity;
use Cake\Network\Exception\NotFoundException;
use Cake\Datasource\ConnectionManager; // This line is required
class TodolistsController extends AppController
{
public function todoadd(){
$connection = ConnectionManager::get('db2'); // 'db2' where my second database is configured
$results = $connection->execute('SELECT * FROM todolists')->fetchAll('assoc');
$this->set('results', $results);
if($this->request->is('post')){
$connection->insert('todolists', [
'title' => $this->request->data['title'],
'description' => $this->request->data['description']
]);
$this->redirect($this->referer);
}
}
}
->TodolistsTable.php
<?php
namespace App\Model\Table;
use Cake\ORM\Table;
class TodolistsTable extends Table
{
public static function defaultConnectionName()
{
return 'db2';
}
public function initialize(array $config)
{
$this->addBehavior('Timestamp');
}
}
Questo è tutto.
Grazie ...
@Abhishek: Grazie amico. –
I documenti sono abbastanza chiari su come fare in modo che le tabelle utilizzino connessioni specifiche, quindi dovresti essere un po 'più specifico su quale sia esattamente il tuo problema, cosa esattamente non capisci, "_I do not understand_" non è utile, e "_Non so come connettere ..._" potrebbe significare qualsiasi cosa. – ndm
@ndm puoi aggiungere un link al documento dove Jigar può dare un'occhiata. – shadab