explode_outer表值函數發生器<一個class="headerlink" href="//www.eheci.com/docs/spark/latest/spark-sql/language-manual/functions/#explode_outer-table-valued-generator-function" title="">

適用於:檢查標記是的磚的SQL檢查標記是的磚運行時

返回一組由un-nesting行expr使用外部語義。

語法<一個class="headerlink" href="//www.eheci.com/docs/spark/latest/spark-sql/language-manual/functions/#syntax" title="">

explode_outer(expr)

參數<一個class="headerlink" href="//www.eheci.com/docs/spark/latest/spark-sql/language-manual/functions/#arguments" title="">

  • expr:數組或地圖表達。

返回<一個class="headerlink" href="//www.eheci.com/docs/spark/latest/spark-sql/language-manual/functions/#returns" title="">

一組行組成的數組的元素或地圖的鍵和值。產生的列explode_outer一個數組是命名上校。列的映射稱為關鍵價值

如果expr一行與年代的數組或映射值。

  • 適用於:檢查標記是的磚12.1和更早的運行時:

    explode_outer隻能放在選擇列表作為根一個表達式或後<一個class="reference internal" href="//www.eheci.com/docs/spark/latest/spark-sql/language-manual/sql-ref-syntax-qry-select-lateral-view.html">側麵圖。當把函數選擇必須沒有其他生成器函數的列表是一樣的選擇列表或<一個class="reference internal" href="//www.eheci.com/docs/spark/latest/error-messages/unsupported-generator-error-class.html">UNSUPPORTED_GENERATOR.MULTI_GENERATOR是提高。

  • 適用於:檢查標記是的磚的SQL檢查標記是的磚運行時12.2及以後:

    調用的<一個class="reference internal" href="//www.eheci.com/docs/spark/latest/spark-sql/language-manual/sql-ref-syntax-qry-select-lateral-view.html">側麵圖條款或者是選擇列表是棄用。相反,調用explode_outer作為一個<一個class="reference internal" href="//www.eheci.com/docs/spark/latest/spark-sql/language-manual/sql-ref-syntax-qry-select-table-reference.html">table_reference

例子<一個class="headerlink" href="//www.eheci.com/docs/spark/latest/spark-sql/language-manual/functions/#examples" title="">

適用於:檢查標記是的磚12.1和更早的運行時:

>選擇explode_outer(數組(10,20.))作為初步的,“火花”;10火花20.火花>選擇explode_outer(地圖(1,“一個”,2,“b”))作為(全國礦工工會,瓦爾),“火花”;1一個火花2b火花>選擇explode_outer((作為數組<int>)),“火花”;火花>選擇explode_outer(數組(1,2)),explode_outer(數組(3,4));錯誤:UNSUPPORTED_GENERATORMULTI_GENERATOR

適用於:檢查標記是的磚的SQL檢查標記是的磚運行時12.2及以後:

>選擇初步的,“火花”explode_outer(數組(10,20.))作為t(初步的);10火花20.火花>選擇全國礦工工會,瓦爾,“火花”explode_outer(地圖(1,“一個”,2,“b”))作為t(全國礦工工會,瓦爾);1一個火花2b火花>選擇*explode_outer(數組(1,2)),explode_outer(數組(3,4));13142324>選擇*explode_outer((作為數組<int>));——使用橫向相關性在磚12.2及以上>選擇*explode_outer(數組(1,2))作為t,橫向explode_outer(數組(3*t上校,4*t上校));13142628