お世話になります。
ExcelデータをADO経由でSQLServerに取込み、その後データの精査を行うプログラムを作成しております。
Excelデータは全てvarchar(255)で構成されたテーブルに投入され、精査が行われます。
ここでつまずいてしまっておりますのは、
”項目2が小数部8桁以内であること”という条件がありまして、どの様にクエリを
起こせば良いか見当が付かないでおります。
処理はプロシージャ内で行っておりまして、以下の様な作りになっております。
select 項目1,
case 項目1の判定結果 end as 結果1,
項目2,
case 項目2の判定結果 end as 結果2
into #TableA
from TableA
(項目1,項目2ともvarchar(255)です)
項目2の小数部が8桁以上はNGとする時の判定方法をご教授いただけますでしょうか。
小数部について
OK '.0'~'.99999999'
NG '.000000001'~'.000000001.....'
不明な点がございましたら補足させて頂きますので、よろしくお願いいたします。
とりあえず「数字であること」というところはチェック済であると仮定して、ポイントのところだけコメントしますと、
REVERSE関数を使うのが一番楽かと思います。
SELECT 項目1,
case 項目1の判定結果 end as 結果1,
項目2,
CASE WHEN CHARINDEX('.',REVERSE(項目2))<=9 THEN 'OK' ELSE 'NG' END as 結果2
INTO #TableA
FROM TableA
「文字列をひっくり返して、小数点が9文字目までにあるならばOK」
ということで。
ただし、1234.123456789はNGでも、1234.123456780はOKにしたいという場合は、もう少し複雑になりますかね。
(Reverseして、floatに変換して、Floorかけて、numericに変換してLenを取るなど。まあ関数をかぶせまくればできなくはないです)