CodeIgniterでOracle Databaseを使う場合の正しい設定方法
結論
今までずっと間違ってましたが、char_set
は AL32UTF8
が正しい。
多分、今時のほとんどのユーザーはこれでOK。
$db['default'] = array(
'dsn' => '',
'hostname' => ((isset($_SERVER['DB_HOSTNAME'])) ? $_SERVER['DB_HOSTNAME'] : 'localhost'),
'username' => ((isset($_SERVER['DB_USERNAME'])) ? $_SERVER['DB_USERNAME'] : ''),
'password' => ((isset($_SERVER['DB_PASSWORD'])) ? $_SERVER['DB_PASSWORD'] : ''),
'database' => '',
'dbdriver' => 'oci8',
'dbprefix' => '',
'pconnect' => false,
'db_debug' => (ENVIRONMENT !== 'production'),
'cache_on' => false,
'cachedir' => '',
'char_set' => 'AL32UTF8',
'dbcollat' => 'utf8_general_ci',
'swap_pre' => '',
'encrypt' => false,
'compress' => false,
'stricton' => false,
'failover' => array(),
'save_queries' => true
);
ちなみに dbcollat
は、oci8 driver は使っていないので気にしなくてOK。
もし違う文字コード使っているかもという場合は、確認してください。
SELECT
VALUE
FROM
NLS_DATABASE_PARAMETERS
WHERE
PARAMETER = 'NLS_CHARACTERSET';
Date: 2019/12/17