【问题标题】:SQL Insert From PowerQuery从 PowerQuery 插入 SQL
【发布时间】:2017-06-07 19:45:13
【问题描述】:

我需要将 excel 上的查询转换为 SQL 上的插入,我不会创建一个适用于任何查询的函数并调用它,所以他需要非常可重用。

let
    SQL = (TableX as table) => let
        // Get Columns Name abd use on the columns INSERT
        SOURCE = TableX,
        Names = Table.ColumnNames(SOURCE),
        ListN = Table.FromList(Names),
        TransposeN = Table.Transpose(ListN),
        CombineN = Table.CombineColumns(TransposeN,Table.ColumnNames(TransposeN),Combiner.CombineTextByDelimiter(",", QuoteStyle.None),"M"),
        ColunmsAsText = List.Single(CombineN[M]),
        // ColumnsasText is all the Columns Name
        // This part I cant do I need to format all columns acording to the type and Combine They
        COLUNMS = (ListN as text) => let
            TYPE = some.function.to.get.type(SOURCE[ListN]),
            if TYPE = date then FIELDS = FIELDS & "'" & Date.ToText([ListN], "yyyy-MM-dd") & "'," else
            if TYPE = text then FIELDS = FIELDS & "'" & [ListN] & "'," else
            if TYPE = number then FIELDS = FIELDS & [ListN] & "," else FIELDS = FIELDS & "#error,"
   in
        FIELDS
        INSERT = "INSERT INTO " & "TABLENAME" & " (" & ColunmsAsText & ") VALUES (" & FIELDS & ");",
        NEWCOLUMNADD = Table.AddColumn(SOURCE, "SQL", each INSERT)
in
    NEWCOLUMNADD
in
    SQL

问题是 FIELDS 变量,我需要组成一个包含所有列的字符串,以及函数“some.function.to.get.type”,对于每一行,输出将是这样的:

 INSERT INTO (Column_name1, Column_name2, Column_name3) value (15, '2017-05-20', 'Text hear');

坦克寻求帮助。

【问题讨论】:

    标签: list function multiple-columns powerquery


    【解决方案1】:

    你想要Value.Type

    Value.Type("abc") = type text
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2014-05-28
      • 1970-01-01
      • 1970-01-01
      • 2016-06-30
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多