
お世話になります。
SQLで1バイト、2バイト混在データでの切出し方法を教えてください。
例:以下のような混在データから左から6バイトを切出したいです。
123:交通費
1234:通勤費
123:交通費 の場合は、「123:交」の形で6バイト きれいに切出せますが、
1234:通勤費 の場合は、「1234:通」の形で6バイトが「通」にかかってしまっています。
この場合、最後の「通」は無視して、「1234:」で出力されるように
したいのです。
何か良い書き方を教えて下さい。
よろしくお願いいたします。
No.2ベストアンサー
- 回答日時:
こんにちは。
以下の方法で、出来ませんか?
SELECT RTRIM(CONVERT(CHAR(6), SUBSTRING(文字列,1,6)))
回答いただきました皆様へ
お忙しい中、ご相談に乗っていただきありがとうございました。
今回は、回答者No.2さんの回答をORACLE用SQLに見直して解決いたしました。
またよろしくお願い申し上げます。
No.1
- 回答日時:
バージョンが無いので分かりませんが
VB6、VBAであれば
こんな感じで
Sub aaa()
Debug.Print Left6("123:交通費")
Debug.Print Left6("1234:通勤費")
End Sub
Function Left6(ByVal vstr As String) As String
'切る位置が全角文字の真中かどうか判定する
If Len(StrConv(LeftB(StrConv(vstr, vbFromUnicode), 6), vbUnicode)) _
= Len(StrConv(LeftB(StrConv(vstr, vbFromUnicode), 5), vbUnicode)) Then
'1バイト前で切ったときに文字数が変わらないのは切った位置が全角文字の後半であるので
'切り位置が正しいと判断する
Left6 = StrConv(LeftB(StrConv(vstr, vbFromUnicode), 6), vbUnicode)
Else '泣き別れのパターン
Left6 = StrConv(LeftB(StrConv(vstr, vbFromUnicode), 5), vbUnicode)
End If
End Function
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
UTF-8で5~6バイトになる文字コ...
-
エクセルシート名の制限を変更...
-
COBOLのCOMP形式について
-
10Mバイトて文字数に すると何...
-
SQLで1バイト、2バイト混在...
-
memcmp バイナリデータの比較方法
-
COBOL PICTUREで X,S,Vの意味
-
バイト列とバイナリ列の違いが...
-
ピクセル,dpiから容量(バイト...
-
IEレジストリのSavedLegacySe...
-
VBAでShift-JISのURLエンコード
-
ラベル表示の桁をそろえたいです。
-
半角、全角の判別方法
-
URLは最高何文字まで可能なので...
-
C++ Builderで文字列をバイトに...
-
64bit対応
-
【VB2005】テキストボックス内...
-
sedコマンドで全ての2バイト文...
-
char str[256]の256の意味は?
-
「1TB」のHDDに日本語は何字入...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
UTF-8で5~6バイトになる文字コ...
-
10Mバイトて文字数に すると何...
-
char str[256]の256の意味は?
-
COBOLのCOMP形式について
-
バイト列とバイナリ列の違いが...
-
エクセルシート名の制限を変更...
-
ピクセル,dpiから容量(バイト...
-
ビットスワップとバイトスワッ...
-
テキストBOXの入力制限について
-
機種依存文字をチェックしたい。
-
「1TB」のHDDに日本語は何字入...
-
C++ Builderで文字列をバイトに...
-
全角半角を調べるライブラリ関...
-
SQLで1バイト、2バイト混在...
-
VB6とSQL Serverの桁の扱い方に...
-
jis x 0208 について
-
VBAでShift-JISのURLエンコード
-
この関数はどのプログラミング...
-
COBOL PICTUREで X,S,Vの意味
-
半角、全角の判別方法
おすすめ情報