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

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

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

BigQueryは、Google Cloud Platformが提供しているビッグデータ解析サービス。数TB(テラバイト)またはPB(ペタバイト)の膨大なデータに対し、SQL風のクエリを実行し、高速で集計・分析を行うサービスです。

SQL

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

Q&A

解決済

2回答

2585閲覧

【SQL】URLパラメータの項目を複数に分割する

Skmotto

総合スコア7

BigQuery

BigQueryは、Google Cloud Platformが提供しているビッグデータ解析サービス。数TB(テラバイト)またはPB(ペタバイト)の膨大なデータに対し、SQL風のクエリを実行し、高速で集計・分析を行うサービスです。

SQL

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

0グッド

1クリップ

投稿2018/09/27 10:05

編集2018/09/27 12:25

質問です。

現在、utmカラムに格納されているURLの中からとある文字列を抜き出して、クエリ実行結果のように分類したいのですが、どうコーディングすればできますでしょうか。(環境はBigqueryを想定してます。)

例)

URL-----
https://oooooo/&utm_source=google&utm_medium=display&utm_campaign=oooooo
https://oooooo/&utm_source=google&utm_medium=display&utm_campaign=oooooo
https://oooooo/&utm_source=yahoo&utm_medium=search&utm_campaign=oooooo

クエリ実行結果

utm_sourceutm_mediumutm_campaign
googledisplayooooooo
googledisplayooooooo
yahoosearchooooooo

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

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

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

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

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

guest

回答2

0

ベストアンサー

splitを使用して分割して取り出すというのもありかな。

SQL

1select 2 split(split(url, '&')[OFFSET(1)], '=')[OFFSET(1)] as utm_source 3 ,split(split(url, '&')[OFFSET(2)], '=')[OFFSET(1)] as utm_medium 4 ,split(split(url, '&')[OFFSET(3)], '=')[OFFSET(1)] as utm_campaign 5from テーブル

投稿2018/09/27 11:39

編集2018/09/27 12:43
sazi

総合スコア25138

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

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

Skmotto

2018/09/27 12:23

ご回答有り難うございます。 このコーディングで行っていこうと思うのですが、加えて質問させてください。 質問項目を詳細に修正させていただきたのですが、上記のようなクエリ結果をだすには、どうコーディングすればよいでしょうか。。 (すみません、非エンジニアでSQL勉強したてで。。 )
sazi

2018/09/27 12:39

SQLという話なら、select ~fromでform句にurlの含まれるテーブルを指定するという事になります。
sazi

2018/09/27 12:43

補足的に回答を修正しました。
Skmotto

2018/09/28 00:58

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

0

INSTR で?の位置を取得し、SUBSTR で部分文字列を取得できますから、左端から最初の?の前まで、最初の?の次から2つ目の? の前まで、2つ目の?の次以降で分割できます。

投稿2018/09/27 10:22

Orlofsky

総合スコア16415

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問