Goal<\/h1>\n
Typical data cleaning tasks include record matching, deduplication, and column segmentation which often need logic that go beyond using traditional relational queries. This has led to development of utilities for data transformation and cleaning. Such software falls into two broad categories. The first category consists of verticals that provide data cleaning functionality for specific domains, e.g., addresses. By design, these are not generic and hence cannot be applied to other domains. The other category of software is that of ETL tools such as Microsoft SQL Server Integration Services (SSIS) that can be characterized as \u201chorizontal\u201d platforms that are applicable across a variety of domains. These platforms provide a suite of additional data cleaning operators but also including relational operators such as select, project and equi-join.<\/p>\n
In the Data Cleaning project, our goal is to define a repertoire of “built-in” operators beyond traditional relational operators with a few core data cleaning operators such that with very less extra code, we can obtain a rich variety of data cleaning solutions. We also investigate their efficient implementation on horizontal ETL engines (such as. SQL Server Integration Services). While for wide usage it is desirable to have generic, domain-neutral operators, it is also important that the operators allow domain specific customizations. Examples of such customizations include plugging in synonyms (e.g., Robert and Bob while dealing with people names), domain-specific tokenization, and token weighting.<\/p>\n
The operators that we have identified and implemented so far include<\/p>\n
- \n
- Fuzzy Lookup (FL) that is used as one of the core operators to perform record matching. The matching can be customized by configuring the tokenization, token weighting and providing transformation rules. We address efficiency by designing a similarity index.<\/li>\n
- Fuzzy Grouping that is used for deduplication. Fuzzy Grouping clusters the pairwise matches produced by Fuzzy Lookup.<\/li>\n
- Column segmentation that segments input strings based on specification of regular expressions that can also reference tables in a database.<\/li>\n<\/ul>\n
One of the contributions of the project is a Data Profiling<\/i> tool that is used to analyze the data quality through a variety of statistics ranging from simple statistics such as the number of null values in a column to more complex statistics such as the strength of keys, foreign keys and functional dependencies.<\/p>\n
Impact<\/h1>\n
- \n
- Fuzzy Lookup and Fuzzy grouping are currently shipping as part of Microsoft SQL Server Integration Services (SSIS)<\/a><\/li>\n
- Fuzzy Lookup is used for geocoding incoming queries in Bing Maps<\/a>.<\/li>\n
- Column Segmentation and Fuzzy Grouping are used for de-duplication of product names and descriptions at the back-end of Bing Shopping<\/a>.<\/li>\n
- Fuzzy Lookup is used in Microsoft\u2019s internal master data management project that maintains information about Microsoft\u2019s customers to match new customers with existing customers.<\/li>\n
- The Data Profiling technology ships as part of Microsoft SQL Server Integration Services (SSIS)<\/a>. A part of the technology that discovers foreign keys in a database ships in Microsoft PowerPivot for Excel<\/a> as part of the SQL Server 2008 R2 release.<\/li>\n
- We have released a Fuzzy Lookup Add-in for Microsoft Excel 2010<\/a> via Microsoft Business Intelligence (BI) Labs that allows users to invoke our approximate matching technology on spreadsheet data in Excel.<\/li>\n<\/ul>\n
If you have questions about this project, please contact the Data Cleaning research team (dcrt@microsoft.com).<\/p>\n<\/div>\n","protected":false},"excerpt":{"rendered":"
Poor data quality is a well-known problem in data warehouses that arises for a variety of reasons such as data entry errors and differences in data representation among data sources. For example, one source may use abbreviated state names while another source may use fully expanded state names. However, high quality data is essential for […]<\/p>\n","protected":false},"featured_media":0,"template":"","meta":{"msr-url-field":"","msr-podcast-episode":"","msrModifiedDate":"","msrModifiedDateEnabled":false,"ep_exclude_from_search":false,"_classifai_error":"","footnotes":""},"research-area":[13556,13555,13547],"msr-locale":[268875],"msr-impact-theme":[],"msr-pillar":[],"class_list":["post-169513","msr-project","type-msr-project","status-publish","hentry","msr-research-area-artificial-intelligence","msr-research-area-search-information-retrieval","msr-research-area-systems-and-networking","msr-locale-en_us","msr-archive-status-active"],"msr_project_start":"2002-07-01","related-publications":[158920,372359,329798,238236,238235,238234,238233,215037,168395,167873,166837,155253,158919,157614,157215,157143,155988,155376,155374,155372,155360],"related-downloads":[],"related-videos":[],"related-groups":[],"related-events":[],"related-opportunities":[],"related-posts":[],"related-articles":[],"tab-content":[],"slides":[],"related-researchers":[{"type":"user_nicename","value":"chrisko","display_name":"Arnd Christian K\u00f6nig","author_link":"Arnd Christian K\u00f6nig<\/a>","is_active":false,"user_id":31427,"last_first":"K\u00f6nig, Arnd Christian","people_section":0,"alias":"chrisko"},{"type":"user_nicename","value":"skaushi","display_name":"Raghav Kaushik","author_link":"Raghav Kaushik<\/a>","is_active":false,"user_id":33680,"last_first":"Kaushik, Raghav","people_section":0,"alias":"skaushi"},{"type":"user_nicename","value":"surajitc","display_name":"Surajit Chaudhuri","author_link":"Surajit Chaudhuri<\/a>","is_active":false,"user_id":33764,"last_first":"Chaudhuri, Surajit","people_section":0,"alias":"surajitc"},{"type":"user_nicename","value":"viveknar","display_name":"Vivek Narasayya","author_link":"Vivek Narasayya<\/a>","is_active":false,"user_id":34602,"last_first":"Narasayya, Vivek","people_section":0,"alias":"viveknar"}],"msr_research_lab":[199565],"msr_impact_theme":[],"_links":{"self":[{"href":"https:\/\/www.microsoft.com\/en-us\/research\/wp-json\/wp\/v2\/msr-project\/169513","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.microsoft.com\/en-us\/research\/wp-json\/wp\/v2\/msr-project"}],"about":[{"href":"https:\/\/www.microsoft.com\/en-us\/research\/wp-json\/wp\/v2\/types\/msr-project"}],"version-history":[{"count":1,"href":"https:\/\/www.microsoft.com\/en-us\/research\/wp-json\/wp\/v2\/msr-project\/169513\/revisions"}],"predecessor-version":[{"id":215701,"href":"https:\/\/www.microsoft.com\/en-us\/research\/wp-json\/wp\/v2\/msr-project\/169513\/revisions\/215701"}],"wp:attachment":[{"href":"https:\/\/www.microsoft.com\/en-us\/research\/wp-json\/wp\/v2\/media?parent=169513"}],"wp:term":[{"taxonomy":"msr-research-area","embeddable":true,"href":"https:\/\/www.microsoft.com\/en-us\/research\/wp-json\/wp\/v2\/research-area?post=169513"},{"taxonomy":"msr-locale","embeddable":true,"href":"https:\/\/www.microsoft.com\/en-us\/research\/wp-json\/wp\/v2\/msr-locale?post=169513"},{"taxonomy":"msr-impact-theme","embeddable":true,"href":"https:\/\/www.microsoft.com\/en-us\/research\/wp-json\/wp\/v2\/msr-impact-theme?post=169513"},{"taxonomy":"msr-pillar","embeddable":true,"href":"https:\/\/www.microsoft.com\/en-us\/research\/wp-json\/wp\/v2\/msr-pillar?post=169513"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}
- Fuzzy Lookup is used for geocoding incoming queries in Bing Maps<\/a>.<\/li>\n
- Fuzzy Lookup and Fuzzy grouping are currently shipping as part of Microsoft SQL Server Integration Services (SSIS)<\/a><\/li>\n