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

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

新規登録して質問してみよう
ただいま回答率
85.50%
Oracle Database 10g

Oracle DatabaseはRDBMSの商品です。具体的な発売商品として知られているのが、 Oracle9i、Oracle10g、Oracle 11gとOracle 12cです。

Seasar2

Seasar2はJ2EE/Java EEでの大規模な開発を効率良く行なうためのフレームワークです。 必要な設定ファイルを従来のものと比べて少なくし、依存性を分離して記述しています。 そのため、生産性の高いプログラム開発が可能です。

Q&A

0回答

3640閲覧

S2JDBCでのマルチバイトの扱いについて

hane_t

総合スコア8

Oracle Database 10g

Oracle DatabaseはRDBMSの商品です。具体的な発売商品として知られているのが、 Oracle9i、Oracle10g、Oracle 11gとOracle 12cです。

Seasar2

Seasar2はJ2EE/Java EEでの大規模な開発を効率良く行なうためのフレームワークです。 必要な設定ファイルを従来のものと比べて少なくし、依存性を分離して記述しています。 そのため、生産性の高いプログラム開発が可能です。

0グッド

0クリップ

投稿2016/12/25 07:06

編集2022/01/12 10:55

shiftJISで受け取ったリクエストよりマルチバイトの文字列を取得し、
S2JDBCでoracle10gに対して検索を行う実装をしようとしています。
リクエストから取得した値をBeanMapに検索条件として設定し、SQLファイル内のパラメータを置き換えて検索をしようとすると、
マルチバイト文字を使ったとき、oraー01460が発生してしまいます。
使うSQLファイルの中は以下のようになっています。

select
store_name
from m_store
where
store_name like '%' || /store/'新宿' || '%'

m_storeはstore_code(char (3))とstore_name(varchar(20))を持つテーブルとします。

oraー01460自体は、リクエストされた変換はできません、と主に日付型への暗黙変換の失敗によるものという情報は得たものの、
今回のように文字列に対しての情報は見つけられませんでした。

また、実行ログに出力されるSQL文をコピーし、SQLplusで実行した場合はエラーは発生しません。

また、リクエストからではなく、コーディングで、storeに直接値を設定しても同様にoraー01460が発生し、
パラメーターの置き換えではなく、SQLファイルに直接マルチバイト文字を記述した場合はエラーにならなかったことから、
置き換え時に何かが起きているものと考えています

上記事象を解決するために良い方法なはないでしょうか?
お力をお貸しください。

補足情報
言語 Java7
フレームワーク seasar2.4
DBoracle10g
APサーバ Tomcat7

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

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

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

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

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

guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問