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

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

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

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

Q&A

1回答

893閲覧

dSQLデータベースから、is_deleted=0でStatus_codeが021 or 031のデータを検索したいです。

cancat

総合スコア313

SQL

SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

0グッド

0クリップ

投稿2017/06/28 03:03

編集2022/01/12 10:55

こんにちは。
Windows10でASP.NETのアプリケーションを開発しています。
Visual Studio 2015 Communityを使っています。

###前提・実現したいこと
SQL文を書きたいです。

###試したこと
SQLデータベースから、is_deleted=0でStatus_codeが021 or 031のデータを検索したいです。

###発生している問題・エラーメッセージ
System.Data.SqlClient.SqlException はハンドルされませんでした。
Class=16
ErrorCode=-2146232060
HResult=-2146232060
LineNumber=1
Message=Invalid column name 'status_codes'.
Invalid column name '021'.
Number=207
Procedure=""
Server=ftmdbsrv-fftest.database.windows.net
Source=.Net SqlClient Data Provider
State=1

###該当のソースコード(1)
配列でとろうとしたが失敗。このほうがうれしい。

C#

1string[] statuscodes = new string[] { "021", "031" }; 2var sql = sqlstring; 3var param = new 4{ 5 StatusCodes = statuscodes, 6 IsDeleted = 0 7}; 8 9var results = DBClient.Connection.Query<table1>(sql, param, DBClient.Transaction);

sqlstring

SQL

1SELECT * 2 FROM [database].[table1] 3 WHERE [is_deleted] = 0 4 [status_codes] IN @StatusCodes

###該当のソースコード
まずひとつとってみようとかんがえた。

C#

1var sql = sqlstring; 2var param = new 3{ 4 IsDeleted = 0 5}; 6var results = DBClient.Connection.Query<table1>(sql, param, DBClient.Transaction);

SQL

1SELECT * 2 FROM [database].[table1] 3 WHERE [is_deleted] = 0 4 and [status_codes] = "021"

SQL

1/****** SSMS の SelectTopNRows コマンドのスクリプト ******/ 2SELECT TOP (1000) [id] 3 ,[id_kana] 4 ,[user_id] 5 ,[result] 6 ,[status_code] 7 ,[is_deleted] 8 ,[created_at] 9 ,[created_by] 10 ,[modified_at] 11 ,[modified_by] 12 FROM [database].[table1]

###補足情報(言語/FW/ツール等のバージョンなど)
Microsoft Visual Studio Community 2015
Version 14.0.25424.00 Update 3
Microsoft .NET Framework
Version 4.6.01038

インストールしているバージョン:Community

Visual C# 2015 00322-20000-00000-AA575
Microsoft Visual C# 2015

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

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

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

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

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

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

momon-ga

2017/06/28 03:33

Invalid column name 'status_codes'. となってますが、テーブル定義というかカラム名がわかる情報を追記ください。
cancat

2017/06/28 04:04

SQL初めてなのですが、これでいかがでしょう。/****** SSMS の SelectTopNRows コマンドのスクリプト ******/
momon-ga

2017/06/28 04:22

なるほど。status_codes でなく、status_code が正しいカラム名ですね
cancat

2017/06/28 05:38

ありがとうございます。そのとおりでした。
guest

回答1

0

Message=Invalid column name 'status_codes'.

「status_codes」という項目名が誤りだ、ということですね。

Status_codeが021 or 031のデータを

書かれているとおり、「or」を使えばよいのでは?

参考:SQL AND OR - 1Keydata SQL入門

投稿2017/06/28 04:21

tkturbo

総合スコア5572

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

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

cancat

2017/06/28 05:38

ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問