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

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

新規登録して質問してみよう
ただいま回答率
85.35%
SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

Q&A

解決済

1回答

2518閲覧

SQLserverでinsertする時の数値

ryuuzu

総合スコア30

SQL Server

SQL Serverはマイクロソフトのリレーショナルデータベース管理システムです。データマイニングや多次元解析など、ビジネスインテリジェンスのための機能が備わっています。

0グッド

0クリップ

投稿2020/04/14 07:45

SQLserverでinsertを使用してテーブルのデータを追加するシステムを考えています。

その時、以下のコードを組みました。

insert into [PREPAID_LOG].[dbo].[Prepaid_log] (log_cardno,log_total,log_charge,log_exchange,log_date) values ('$cardNo$',$Total$,$charge$,$exchange$,getdate())

カラムの内、最初のlog_cardnoとlog_dateはそれぞれchar型、date型、
内側3つはint型で取得するように設定してあります。

取得は他のテーブルを参照して取得しているのですが、int型の3つが4桁以上の時自動で
コンマ,がつくため場合によっては3行目が

values ('1234567890123456',10,000,7,000,3,000,getdate())

みたいな感じになり、コンマが増えてしまってエラーが発生します。

insert into [PREPAID_LOG].[dbo].[Prepaid_log] (log_cardno,log_miseCD,log_total,log_prepaid,log_exchange,log_fail,log_date) values ('$cardNo$',0,'$Total$','$Prepaid$','$Exchange$',0,getdate())

といった感じでint型3つを''で囲ってしまうとSQLがvarchar型でとらえてしまいます。

数値をint型のまま保存するにはどのようにしたらよろしいでしょうか?
なお、テーブルに保存する際には数値にコンマはついていなくても大丈夫なので
数値型のままコンマだけ抜く方法でも構いません。

よろしくお願いいたします。

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

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

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

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

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

gentaro

2020/04/14 07:51

このクエリは何使って実行される前提なんですか?SQLCMDモード? > int型の3つが4桁以上の時自動でコンマ,がつくため 何のプログラム使ってるのかわかんないですが、それ文字列表現ですよね? 置換すればいいだけでは?
ryuuzu

2020/04/17 04:44

ありがとうございます。Cintで数値型に置換したら保存ができました。ありがとうございました。
guest

回答1

0

自己解決

すみません、自己解決いたしました。最初にテーブルから拾ってきた数値がvarchar型だったみたいです。それをint型と勘違いしてSQLが''で囲ったものをvarchar型でとらえていると思ってしまっておりました。
varchar型のカラム三つをCIntで数値型に変換したら数値型で保存されるようになりました。失礼いたしました。
totalint=Cint(total)
と定義した上でSQLを入力したら保存できました。

投稿2020/04/17 04:55

ryuuzu

総合スコア30

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問