duanchi19820419 2014-08-25 20:32
浏览 62
已采纳

Kohana 3.3 Database :: instance('name')不起作用

I have an issue with Kohana 3.3 and using different database configurations. I have a config/database.php with 'default' config and 'other' like this:


return array
(
'default' => array
(
    'type'       => 'MySQL',
    'connection' => array(
        'hostname'   => 'localhost',
        'database'   => 'database-one',
        'username'   => 'root',
        'password'   => 'password',
        'persistent' =>  FALSE,
    ),
    'table_prefix' => '',
    'charset'      => 'utf8',
    'caching'      => FALSE,
),

'other' => array  
(
    'type'       => 'MySQL',
    'connection' => array(
        'hostname'   => 'localhost',
        'database'   => 'database-two',
        'username'   => 'root',
        'password'   => 'password',
        'persistent' =>  FALSE,
    ),
    'table_prefix' => '',
    'charset'      => 'utf8',
    'caching'      => FALSE,
));

But in a Controller or Model when trying to use:

 Database::instance('other'); 

Kohana will still use the 'default' configuration. What am I doing wrong?

Thanks!

  • 写回答

2条回答 默认 最新

  • duannai1883 2014-08-27 10:29
    关注

    If you would like to change currently used connection by kohana try this:

    Database::$default = 'other';
    

    From this line your code will use 'other' connection till you will switch it again to 'default' using same way.

    You can also use another DB configuration once when executing the query in simple way:

    DB::...->execute('other');
    

    Or if you store your DB instance earlier:

    $other = Database::instance('other');
    DB::...->execute($other);
    

    By ... I mean your query.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 对于这个复杂问题的解释说明
  • ¥50 三种调度算法报错 采用的你的方案
  • ¥15 关于#python#的问题,请各位专家解答!
  • ¥200 询问:python实现大地主题正反算的程序设计,有偿
  • ¥15 smptlib使用465端口发送邮件失败
  • ¥200 总是报错,能帮助用python实现程序实现高斯正反算吗?有偿
  • ¥15 对于squad数据集的基于bert模型的微调
  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存
  • ¥15 CST保存项目时失败