
ジョブでバッチ処理を作成していますが、テーブルからある数式を文字列として取得し、文字列内にある変数を実際の値と置き換え、それを数式として処理する必要があります。
T-SQLにはその機能がないため、vbsのEVAL関数を使って処理しようと考えています。
テーブルから取得した数式を直接SQL文に記述し、「数式 AS フィールド名」として取得しようとも考えましたが、数式に^(べき乗)が存在し、数式をT-SQLに変換することが複雑になってしまうため、あきらめました。
SQLServerのジョブ(もしくはストアドプロシージャ内)からパラメータを与えてVBSを実行させ、VBSより結果を返してもらうコーディング(設定)はどうすればできるのでしょうか?
No.2ベストアンサー
- 回答日時:
>a^2.1 という具合に小数点のべき乗の部分が
あ。すみません。読みきれてませんでした。
で、そのあたり調べてみると…。
T-SQLでのべき乗は、"^"では行われないみたいです。
"^"は、「ビットごとの排他的 OR」です。
ということで、Power関数を使用するようです。
declare @a as float
@a=2
power(cast(@a as float),0.5)
で、ルート2が帰ってきます。
(詳細はBooksOnline参照)
#言語によって、四則演算以外は違ってたりするので、ヘルプなどで確認するほうがいいかとおもいます。
SQLServerからVBSコードの実行方法だけわかれば良いと思っていたので説明不足で申し訳ありません。
計算式はユーザによって入力されるため、べき乗はPOWERではなく ^ で入力されます。
その式をPOWERに置き換えるプログラムを作成するのはかなりハードではないかと思われます。
データ変換サービスのローカルパッケージ内でActiveXスクリプトタスクを使ってテーブル全体を変換する方法も試しましたが、処理がかえって複雑になってしまいました。
テーブルから数値データを1件ずつFetchしながら計算処理させ、なおかつべき乗は^で記述できる方法があればベストなのですが...。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Access VBA [リモートサーバー...
-
ACCESS2007 フォーム 「バリア...
-
Accessでクエリを完了できませ...
-
SSIS 変数の値をSQL実行タスク...
-
重複するキーから一番古い年月...
-
SI Object Browserのテーブルス...
-
SQLServerで同一条件レコードの...
-
アクセスのテーブルからエクス...
-
時系列データの抜けの調べ方
-
既に使用されているので、使用...
-
SQLスクリプトを自動生成する方法
-
bcpインサートでのフォーマ...
-
DBMAGICのプログラム解析
-
ACCESS-リンクテーブルの設定で...
-
sqlplusでバックスペースが効か...
-
あるテーブルのデータを追加、...
-
ユニオンクエリの結果をテーブ...
-
Access カレントレコードがあり...
-
ボタンをクリックした回数をカ...
-
ExcelからAccess2013DBを更新す...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ACCESS2007 フォーム 「バリア...
-
Access VBA [リモートサーバー...
-
Accessでクエリを完了できませ...
-
ACCESSのODBCリンクテーブルに...
-
大きなテーブルに対する問い合...
-
VBAの実行時エラー'2522'について
-
テーブル作成後なんですが、Pri...
-
accessでSQL実行時のテーブル名...
-
実行時エラー3086 削除クエリ...
-
Select ~ into ~ で作成した...
-
アクセスのワークシート変換に...
-
ユニオンクエリで繋げられるテ...
-
インデックスを調べる方法は?
-
AccessのテーブルをSQL Server...
-
PhpMyAdminで作成して実行せよ...
-
Access Update文の副問い合わせ
-
TRY CATCHでシステムエラーを検...
-
Access VBA 読み取り専用かチェ...
-
SQL Serverのテーブルってどう...
-
SSIS 変数の値をSQL実行タスク...
おすすめ情報