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

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

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

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

Q&A

解決済

1回答

5695閲覧

Withを2つ使うとエラーがでる

tokita.

総合スコア61

SQL Server

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

0グッド

0クリップ

投稿2022/03/16 00:56

前提・実現したいこと

SQLで特定テーブルにおける2文字以上のフィールド名を抽出したいです(実際にはより複雑な条件があります)

発生している問題・エラーメッセージ

メッセージ 156、レベル 15、状態 1、行 10 キーワード 'with' 付近に不適切な構文があります。 メッセージ 319、レベル 15、状態 1、行 10 キーワード 'with' 付近に不適切な構文があります。このステートメントが共通テーブル式、xmlnamespaces 句、または変更追跡コンテキストの句の場合は、前のステートメントをセミコロンで終了してください。

該当のソースコード

SQL

1with cnameb as( 2 SELECT name 3 FROM sys.columns 4 WHERE object_id = (SELECT object_id 5 FROM sys.views 6 WHERE name = 'table' 7 ) 8) 9 10with cname as ( 11 select * from cnameb where len(name)>1 12) 13 14select * from cnameb

試したこと

googleで検索等しましたが解決方法わかりませんでした
できれば上の形(Withを2つ使った形)のまま実装したいのですが、どうすればエラーは解消できるでしょうか

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

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

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

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

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

guest

回答1

0

ベストアンサー

WITHを複数書きたい場合は、二つめ以降にはWITH句をつけず、カンマ区切りで記述します。

SQL

1with cnameb as( 2 SELECT name 3 FROM sys.columns 4 WHERE object_id = (SELECT object_id 5 FROM sys.views 6 WHERE name = 'table' 7 ) 8), 9 10cname as ( 11 select * from cnameb where len(name)>1 12)

投稿2022/03/16 01:19

nukasa

総合スコア406

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

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

tokita.

2022/03/16 04:51

無事実現できました。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.31%

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

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

質問する

関連した質問