お世話になります。
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.....'
不明な点がございましたら補足させて頂きますので、よろしくお願いいたします。
No.2ベストアンサー
- 回答日時:
とりあえず「数字であること」というところはチェック済であると仮定して、ポイントのところだけコメントしますと、
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を取るなど。まあ関数をかぶせまくればできなくはないです)
No.3
- 回答日時:
小数部分が8桁より多い場合、'NG'を表示させます。
select 'NG'
where ( 100000000*(123.123456789-floor(123.123456789))
-floor(100000000*(123.123456789-floor(123.123456789))) )>0
要するに、小数部分を100000000倍してさらに小数部分があるかどうかを調べることで小数部分が8桁より多いかどうか調べています。
No.1
- 回答日時:
SQLサーバーの関数をよく知らないため、考え方だけ。
項目2が全部数値であると仮定できるなら
・項目2を数値に変換
・項目2の100,000,000倍を小数点以下切り捨て
・これを項目2の100,000,000と比較
結果が同じなら、OK。違えばNGです。
文字列から数値への変換の関数をto_num()とし、切り捨ての関数をtrunc()とすると
to_num(項目2)*100000000 = trunc(to_num(項目2)*100000000)
という感じでしょうか。
ただし、「項目2*10,000,000」の結果がsqlサーバーで扱える数値の範囲内に収まっていることを条件とします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- システム CSVファイルのマッピング処理の省力化 1 2022/11/24 00:01
- Visual Basic(VBA) 【前回の続きです、ご教示ください】VBAの記述方法がわかりません。 2 2022/08/16 16:44
- Excel(エクセル) 表示形式、文字列セル(列)に数式を入力するには マクロ 1 2022/09/18 10:53
- Visual Basic(VBA) 【前回の続き続きです、ご教示ください】VBAの記述方法がわかりません。 2 2022/08/24 20:49
- Visual Basic(VBA) Excel VBAのリストボックスの値を他のフォームに反映させる方法を教えてください。 2 2023/07/14 14:06
- Visual Basic(VBA) 【ご教示ください】VBAの記述方法がわかりません。 2 2022/08/12 21:28
- Visual Basic(VBA) Excelで下記のようにマクロを作ったところ、一回目は実行できたのですが、二回目以降「実行時エラー1 1 2022/03/25 08:08
- その他(プログラミング・Web制作) Pythonで、データファイルと列名ファイルを1つのファイルにしたいです。 1 2023/07/27 20:29
- Ruby pandasでsqlite3にテーブル作成・追加・読み出しでindexの取り扱い方教えてください 5 2023/03/08 09:57
- Access(アクセス) access フォーム 大分類、小分類 1 2022/08/11 18:03
このQ&Aを見た人はこんなQ&Aも見ています
-
好きなおでんの具材ドラフト会議しましょう
肌寒くなってきて、温かい食べ物がおいしい季節になってきましたね。 みなさんはおでんの具材でひとつ選ぶなら何にしますか? 1番好きなおでんの具材を教えてください。
-
人生最悪の忘れ物
今までの人生での「最悪の忘れ物」を教えてください。 私の「最悪の忘れ物」は「財布」です。
-
初めて自分の家と他人の家が違う、と意識した時
子供の頃、友達の家に行くと「なんか自分の家と匂いが違うな?」って思いませんでしたか?
-
自分のセンスや笑いの好みに影響を受けた作品を教えて
子どもの頃に読んだ漫画などが その後の笑いの好みや自分自身のユーモアのセンスに影響することがあると思いますが、 「この作品に影響受けてるな~!」というものがあれば教えてください。
-
ハマっている「お菓子」を教えて!
この世には、おいしいお菓子がありすぎて……。 次何を食べたらいいか迷っています。 みなさんが今、ハマっている「お菓子」を教えてください!
-
SQL Serverにおける小数部の0表記について
その他(プログラミング・Web制作)
-
【SQLサーバ】float型における小数点以下のデータを抽出する方法について
SQL Server
-
SQLServerで文字列の末尾からある位置で取出
SQL Server
-
-
4
like演算子内に変数って使えないんですか?
その他(プログラミング・Web制作)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・ハマっている「お菓子」を教えて!
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excel 2019 のピボットテーブル...
-
エクセルVBAで5行目からオート...
-
BIOSでAHCIに設定したいが、項...
-
Access テキスト型に対する指定...
-
Oracle 2つのDate型の値の差を...
-
空白をそのままインポートする...
-
access2000:フォームで入力し...
-
ビューでのデータエラー 「0で...
-
SQLでの変数の扱いについて
-
【至急】Accessのフィールドの...
-
ピボットテーブルについて 列フ...
-
SUBSTRING 関数に渡した長さの...
-
2行目を表示できますか?
-
ORACLEでLONG項目からCHAR項目...
-
SQLでの項目名の日本語化
-
Excelで空白以外の値がある列の...
-
エクセルマクロにて最終行まで...
-
ACCESSからORACLEへの移行について
-
エクセルグラフの凡例スペース
-
セルの右クリックで出る項目を...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel 2019 のピボットテーブル...
-
エクセルVBAで5行目からオート...
-
Oracle 2つのDate型の値の差を...
-
Access テキスト型に対する指定...
-
セルの右クリックで出る項目を...
-
エクセルグラフの凡例スペース
-
SUBSTRING 関数に渡した長さの...
-
必須入力項目と入力必須項目
-
空白をそのままインポートする...
-
VBAで複数の数式セルを最終行ま...
-
Accessで数値型にNULLをInsert...
-
datファイルからaccessにインポ...
-
access2000:フォームで入力し...
-
複数のレコードを1つのレコード...
-
ORACLEでLONG項目からCHAR項目...
-
SELECT文でLEFT関数を使うと未...
-
条件に一致した列の非表示の仕...
-
他テーブルで一致する列から名...
-
BIOSでAHCIに設定したいが、項...
-
APN設定について教えていただけ...
おすすめ情報