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

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

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

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

CakePHP

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

Q&A

解決済

1回答

2505閲覧

cakephp3 encodingError

XYZA

総合スコア20

SQL Server

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

CakePHP

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

0グッド

0クリップ

投稿2016/07/06 01:24

###前提・実現したいこと
現在SQLserver2008へDBをつなごうと思っているのですが、encodingErrorとなっており困っています。

※別に上げたほうが回答が早く得られると思い、別途質問を上げさせていただいております。
以下別途上げている質問です。
https://teratail.com/questions/39752

###発生している問題・エラーメッセージ

Error: SQLSTATE[IMSSP]: An invalid encoding was specified for SQLSRV_ATTR_ENCODING.

###多分、該当のソースコード
\vendor\cakephp\cakephp\src\Database\Driver\Sqlserver.php
※Composerで作成したときより変更していません。

php

1/** 2 * SQLServer driver. 3 */ 4class Sqlserver extends Driver 5{ 6 7 use PDODriverTrait; 8 use SqlserverDialectTrait; 9 10 /** 11 * Base configuration settings for Sqlserver driver 12 * 13 * @var array 14 */ 15 protected $_baseConfig = [ 16 'persistent' => false, 17 'host' => 'localhost\SQLEXPRESS', 18 'username' => '', 19 'password' => '', 20 'database' => 'cake', 21 // PDO::SQLSRV_ENCODING_UTF8 22 'encoding' => 65001, 23 'flags' => [], 24 'init' => [], 25 'settings' => [], 26 ]; 27 28 /** 29 * Establishes a connection to the database server 30 * 31 * @return bool true on success 32 */ 33 public function connect() 34 { 35 if ($this->_connection) { 36 return true; 37 } 38 $config = $this->_config; 39 $config['flags'] += [ 40 PDO::ATTR_PERSISTENT => $config['persistent'], 41 PDO::ATTR_EMULATE_PREPARES => false, 42 PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION 43 ]; 44 45 if (!empty($config['encoding'])) { 46 $config['flags'][PDO::SQLSRV_ATTR_ENCODING] = $config['encoding']; 47 } 48 49 $dsn = "sqlsrv:Server={$config['host']};Database={$config['database']};MultipleActiveResultSets=false"; 50 $this->_connect($dsn, $config); 51 52 $connection = $this->connection(); 53 if (!empty($config['init'])) { 54 foreach ((array)$config['init'] as $command) { 55 $connection->exec($command); 56 } 57 } 58 if (!empty($config['settings']) && is_array($config['settings'])) { 59 foreach ($config['settings'] as $key => $value) { 60 $connection->exec("SET {$key} {$value}"); 61 } 62 } 63 return true; 64 } 65

###試したこと
'encoding' => 65001,の箇所を'encoding' => 2024,(Windows-31J)に変更してみましたが同様のエラーが発生しました。
ついでに'encoding' => 932(SIFT_JIS)もだめでした。

修正する場所が悪いのでしょうか?

###補足情報(言語/FW/ツール等のバージョンなど)
cakephp3/sqlserver2008

DBはutf-8となっております。

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

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

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

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

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

guest

回答1

0

自己解決

php

1\config\app.php 2 3'Datasources' => [ 4 'default' => [ 5 'className' => 'Cake\Database\Connection', 6 'driver' => 'Cake\Database\Driver\Mysql', 78910111213 ], 14 '****system' => [ 15 'className' => 'Cake\Database\Connection', 16 'driver' => 'Cake\Database\Driver\Sqlserver', 17 'persistent' => false, 18 'host' => '***.***.*.***\instance_name', 19 20 //'port' => 'non_standard_port_number', 21 'username' => 'sa', 22 'password' => '********', 23 'database' => '*****', 24 'encoding' => PDO::SQLSRV_ENCODING_UTF8, 25 'timezone' => 'UTC', 26 'flags' => [], 27 'cacheMetadata' => true, 28 'log' => false, 29 'quoteIdentifiers' => false, 30 'url' => env('DATABASE_URL', null), 31 ],

参考文献:http://stackoverflow.com/questions/20042778/cakephp-sqlserver-encoding

投稿2016/07/06 08:52

XYZA

総合スコア20

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問