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

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

新規登録して質問してみよう
ただいま回答率
85.48%
SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

PHP

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

CodeIgniter

CodeIgniterは、PHP向けオープンソースのWebアプリケーションフレームワークです。CodeIgniterは覚える構文が少なく、自由度も高いため、PHPを理解していれば構築が簡単です。

Q&A

解決済

2回答

2616閲覧

CodeIgniter3での文字化けについて

a0841_1974

総合スコア29

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

PHP

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

CodeIgniter

CodeIgniterは、PHP向けオープンソースのWebアプリケーションフレームワークです。CodeIgniterは覚える構文が少なく、自由度も高いため、PHPを理解していれば構築が簡単です。

0グッド

0クリップ

投稿2017/11/10 03:25

いつもお世話になっております。

以下の手順を実施しますと、a1の内容が文字化けします。

a1の結果を表示する際も文字化けをなくしたいのですが、
ご存知の方がいらっしゃれば、
対応方法を教えて頂けますでしょうか。

【手順】
手順1 実施プログラム1を実施する。
手順2 実施プログラム2を実施する。

【環境】
XAMP7.0
CodeIgniter3
(APサーバーのOSは、Windows7です)

SQL Server2008 R2
(DBサーバーのOSは、Windows7です)

【実施プログラム1】
class Db_sample1 extends CI_Controller{
function index(){
$this->load->database();
$moji='あ';
$sql = "INSERT INTO test (a1,a2) VALUES(?,?)";
$query = $this->db->query($sql, array($moji,$moji));

}

}

【実施プログラム2】
class Db_sample2 extends CI_Controller{
function index(){
$this->load->database();
$sql = "SELECT a1 , a2 FROM test";
$query = $this->db->query($sql);
var_dump($query->result()) ;
}
}

【testテーブルの型】
a1 varchar(50)
a2 nvarchar(100)

【結果】
array(1) { [0]=> object(stdClass)#25 (2) { ["a1"]=> string(6) "あ੢" ["a2"]=> string(3) "あ" } }

【database.phpの設定内容】
$db['sqlserver'] = array(
'dsn' => '',
'hostname' => '192.168.10.42',
'username' => 'user1',
'password' => 'manager',
'database' => 'testDB',
'dbdriver' => 'sqlsrv',
'dbprefix' => '',
'pconnect' => FALSE,
// 'db_debug' => (ENVIRONMENT !== 'production'),
'db_debug' => FALSE,
'cache_on' => FALSE,
'cachedir' => '',
'char_set' => 'utf8',
'dbcollat' => '',
'swap_pre' => '',
'encrypt' => FALSE,
'compress' => FALSE,
'stricton' => FALSE,
'failover' => array(),
'save_queries' => TRUE
);

以上です。
よろしくお願いいたします。

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

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

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

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

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

guest

回答2

0

自己解決

database.phpのdbdriverの設定をsqlsrvからpdoに変更したら、
問題が解決されました。

$db['sqlserver'] = array(
'dsn' => 'sqlsrv:Server=XXX.XXX.XXX.XXX;Database=testDB',
'hostname' => '',
'username' => '',
'password' => '',
'database' => '',
'dbdriver' => 'pdo',
'dbprefix' => '',
'pconnect' => FALSE,
// 'db_debug' => (ENVIRONMENT !== 'production'),
'db_debug' => FALSE,
'cache_on' => FALSE,
'cachedir' => '',
'char_set' => 'utf8',
'dbcollat' => '',
'swap_pre' => '',
'encrypt' => FALSE,
'compress' => FALSE,
'stricton' => FALSE,
'failover' => array(),
'save_queries' => TRUE
);

投稿2017/11/16 14:28

a0841_1974

総合スコア29

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

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

0

ソースファイルのエンコードとPHPの内部文字エンコーディング、テーブルの文字コードはすべてUTF-8で統一してください。またソースファイルの改行コードはLFにすること。

環境がwindowsと聞くとソースファイルがshift-jisでLFになっている気がします。

投稿2017/11/15 22:29

nullbot

総合スコア910

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

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

a0841_1974

2017/11/16 01:35

ご連絡ありがとうございます。 ソースファイルのエンコード、PHPの内部文字エンコーディングはUTF-8です。 ソースファイルの改行コードはLFにしましたが、同じ問題が発生しております。 また、テーブルの文字コードですが、 SQLServerはDB、テーブル毎に文字コードを設定する事は可能なのでしょうか?
nullbot

2017/11/16 02:22

ごめんなさい、テーブルではなくDBですね。ただSQLServerは使ったことがないので変更可能かもわかりません。 あと気になったのはこの実行結果ってコマンドプロンプトではなくブラウザで表示させたものでしょうか? var_dumpではなくprint_rを使うとどうなりますか?
a0841_1974

2017/11/16 14:26

ご連絡ありがとうございます。 dbdriverをsqlsrvではなく、pdoにしたら問題が発生しませんでした。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問