Power Query: The Wrong Type
4 December 2019
Welcome to our Power Query blog. This week, I look at a problem when assigning data types to columns.
Last time, I looked at several methods for setting the data type when creating a table. I used Table.FromRecords, Table.FromColumns and #table.
To recap, the Table.FromRecords method had three steps (which I could combine to two).
data:image/s3,"s3://crabby-images/d6e2e/d6e2e19778d3401847a61dc547b1bac5275802a3" alt=""
The M code I used was:
= Table.FromRecords({ [Name = "Mary", Employee_Number = 1], [Name = "Paul", Employee_Number = 18], [Name = "John", Employee_Number = 18], [Name = "Newbie", Employee_Number = 150]} )
data:image/s3,"s3://crabby-images/bc24c/bc24cb304227a775686c1927c5c927201ec4186a" alt=""
The M code I used to define the data types was:
= type table[Name = text, Employee_Number = number]
data:image/s3,"s3://crabby-images/b932d/b932d16756b6f76c48184407ec81589286f045b9" alt=""
I created another step to assign this type to my table.
data:image/s3,"s3://crabby-images/c22d7/c22d76ef6b010a307366ee9b85c3ea3b54296e59" alt=""
The M code I used was:
= Value.ReplaceType(Source, Custom1)
data:image/s3,"s3://crabby-images/f9339/f9339d5721a946b7dae20925f28709f28d94c6e0" alt=""
Using #table, I could refine the table creation to one step:
data:image/s3,"s3://crabby-images/c34d9/c34d97fad0e85883a57a3ddb4f595393d2b1f824" alt=""
The M code I used was:
= #table(type table[Name = text, Employee_Num = number],{{"Mary",1},{"Paul",18},{"John",15},{"Newbie",150}})
I also used Table.FromColumns, which accepts the table types as the second parameter.
data:image/s3,"s3://crabby-images/80d10/80d107fa5ef80eae679cda6c56ffe82346b9295d" alt=""
The M code I used was:
= Table.FromColumns({{"Mary", "Paul", "John", "Newbie"},{1,18,15,150}},type table [Name = text, Employee_Number = number])
data:image/s3,"s3://crabby-images/dbf69/dbf69ab91f721224e7901fbcabf02e7b25afe2a5" alt=""
There are some disadvantages to declaring data types in this way. For example, in the next screen, I have entered a step to create a new table.
data:image/s3,"s3://crabby-images/dce3c/dce3c71225d4d2f3dd836941011540dd91d6230b" alt=""
There is a deliberate mistake, but when I upload my step, everything looks fine:
data:image/s3,"s3://crabby-images/15b4d/15b4d282885b6db921591df492792767d4fe3724" alt=""
I ‘Close & Load To’ so that I can load my query.
data:image/s3,"s3://crabby-images/2d1c6/2d1c64735808c7c5daa8e10802af1824accac6c9" alt=""
I decide to ‘Add this data to the Data Model’.
data:image/s3,"s3://crabby-images/cd82d/cd82d24143a7d1fc0923fa3b208379cc3ee7ca68" alt=""
I can view the error in Excel, and correct it using the dropdown.
data:image/s3,"s3://crabby-images/95651/9565194d6ee048c5b70518a3b50a41b251ee30b7" alt=""
But that does not solve the issue with the data model.
data:image/s3,"s3://crabby-images/b4524/b452424a3950a4b650f2adb270539ce2763dc83c" alt=""
I have four rows loaded and one error. I try clicking on ‘1 error’ to see what has happened.
data:image/s3,"s3://crabby-images/7f6d9/7f6d90c8d47874cd0acc95a683a7208ceeb428f4" alt=""
Not very useful!
In my simple example, I know that one row has failed to load because I put “15” instead of 15 as John’s employee number. However, in a long list of data, this would be hard to spot. The error doesn’t appear because the query doesn’t have an error flagged. This is the problem when I manually define the column types in the table.
When I go to look at the Data Model (from the ‘Power Pivot’ tab) there is no data loaded!
data:image/s3,"s3://crabby-images/024cd/024cde9e9e8bd8bc236a4710d4bff8ed97b4f6a4" alt=""
If I am defining datatypes for columns manually, I need to bear in mind that I am bypassing the checks that Power Query uses. This functionality should be used with caution.
Come back next time for more ways to use Power Query!