《大数据原理:复杂信息的准备、共享和分析》一一2.4 糟糕的标识方法

本文涉及的产品
云原生大数据计算服务 MaxCompute,5000CU*H 100GB 3个月
云原生大数据计算服务MaxCompute,500CU*H 100GB 3个月
简介: 本节书摘来自华章出版社《大数据原理:复杂信息的准备、共享和分析》一 书中的第2章,第2.4节,作者:[美] 朱尔斯 J. 伯曼(Jules J. Berman)著 ,更多章节内容可以访问云栖社区“华章计算机”公众号查看。

2.4 糟糕的标识方法
以前我总想成为别人,但现在我意识到我更应该成为特别的自己。
―Lily Tomlin

可怜的标识符名字。一种显而易见的情况是,名字不唯一,例如姓氏Smith、Zhang、Garica、Lo,名字John、Susan);另一个情况是,一个名字有很多表示方法,可能的原因有很多,以下列出部分:
1.姓氏的修改,如du Bois、DuBois、Du Bois、Dubois、Laplace、La Place、van de Wilde、Van DeWilde等。
2.口音,如重音符、变音符、停顿、腭化辅音、连音符、双元音、元音变音、音调等。
3.特殊字符,如妗?
4.一个人可能有多个中间名,这些可能不会被记录下来。例如,平时,我们总会使用中间名来代替全名,而法律文件中仍保留我们的全名写法。
5.一个人名有拉丁语等其他版本,例如Carl Linnaeus、Carl von Linne、Carolus Linnaeus、Carolus a Linne。
6.复姓和中间名混淆。例如,Jean-Jacques Rousseau还是Jean Jacques Rousseau, Louis-Victor-Pierre-Raymond、7th duc de Broglie、Louis Victor Pierre Raymond Seventh duc deBroglie搞不清姓和中间名。
7.文化差异导致名字顺序被打乱。
8.改名,如别名、笔名、一时兴起的变化,而这些都是合法的。
除了上面这些显而易见的后果,利用名称作为标识符还有一些潜在问题。例如,在名字中使用重音字符会破坏拼写的正确性和字母顺序。一个包含变音字符的名字放到哪里?假装看不到变音并且把这个名字按字母顺序放到普通字符里?还是要基于ASCII数字分配方法让变音字母不会出现在按字母顺序排列的普通字母组成的单词列表中?同样的问题也适用于其他特殊的字符。
姓氏编辑也存在类似问题。姓氏de Broglie是按D、d还是按B排序?如果按B排序,要是写成deBroglie又该怎么处理?
遇到这类问题,不可能完全按照字母顺序排列名字列表。这意味着按照字母排序设计的搜索程序容易出错。
我曾与众多智能化领域的专业人才进行谈话,他们需要为人分配标识符。在每次谈话时,他们都好像觉得有必要解释,虽然人名不能作为一个标识符,但人名+出生日期这种组合基本上可以满足标识符唯一性的需要。有时候,他们又会说,人名+出生日期+社会安全号码的组合提供了完美的标识符,因为没有两个人有相同的人名、相同的出生日期和相同的社会安全号码。这种说法简直可以称得上愚蠢,完全忽略了标识的意义所在。正如我们将看到的,就前面所言,为个人或任意数据对象分配唯一的标识符是相对容易的事情,但对于数据管理者而言,他们关心的是如何确保分配到每个人的标识符是唯一的。
让我们来看看,以名字+出生日期的组合来创建标识时会发生什么。而名字+出生日期+社会安全号码的组合会在稍后给出。
例如,Mary Jessica Meagher,出生于1912年7月7日,她决定在10个银行里开个人账户。一些银行有申请表,她也准确地填完了。剩下的银行通过柜员问她一些问题,并直接将回答转录到计算机终端,就这样登记她的账户。该女士无法看到电脑屏幕,无法检查各条目内容的准确性。
以下是她的名字+出生日期可能的写法:

  1. Marie Jessica Meagher,June 7,1912(柜员把Mary错写成Marie)。
  2. Mary J. Meagher,June 7,1912(申请表需要写中间名全称,而不是名字全称)。
  3. Mary Jessica Magher,June 7,1912(柜员拼错了姓氏)。
  4. Mary Jessica Meagher,Jan 7,1912(申请表要求出生月用三个字母简写,Jun被转换成了Jan)。
  5. Mary Jessica Meagher,6/7/2012(申请表只留出了两格填写年份,银行注册奇迹般地让女士一个世纪后又复活了)。
  6. Mary Jessica Meagher, 7/6/12(按照欧洲常用顺序,申请表询问了出生的日、月、年)。
  7. Mary Jessica Meagher,June 1,1912(申请表里的7被看成了1)。
  8. Mary Jessie Meagher,June 7,1912(中间名的非正式写法让该女士听着像个孩子)。
  9. Mary Jessie Meagher,June 7,1912(柜员把名字看做一个男性的写法)。
  10. Marie Jesse Mahrer,1/1/12(柜员点击速度过快导致字母部分缺失,而计算机自动给添加了其他错误的字母)。
    这样,Mary Jessica Meagher在10个银行里拥有了10个不同的标识符。即便Mary重新注册登记,结果可能还是一样。

如果加上社会安全号码,情况会更复杂。人的社会安全号码绝不是唯一的。我们很少会携带社会保障卡原件,我们的社会安全号码也会因记忆错误而写错(“你的意思是我这些年都记错了?”),数据录入错误(“字符transpositoins”,我的意思是“字符transpositions”,这是很常见的),或者意图欺骗(“我不想给那些人我真实的安全号”),或者完全的乱写(“我不记得了,就随便写了”),又或者仿照(“我没有医疗保险,所以我会用我朋友的社会安全号码”)。通过要求患者携带社保卡来减少错误并没有起多大作用。
迫使个人提供社会安全号码的做法的合法性令人怀疑。社会安全号码原本是用于在社会保障体系里验证一个人的身份,最近,还被用来追踪税务交易(包括银行账户、发放的薪金)。社会安全号码在其他地方的使用并不受法律保护。(美国)社会保障法(Section 208 of Title 42 U.S. Code 408)明确禁止他人或机构强迫个人提供他们的社会安全号码。
考虑到社会安全号码在大多数事务中的不可靠性,以及要求个人泄露自己的社会安全号码的脆弱合法性,审慎的医疗设计标识系统必须限制使用这些数字。将姓名和出生日期与社会安全号码结合的思想无形中使得标识系统将违反严格的一对一个的客户规则。

相关实践学习
基于MaxCompute的热门话题分析
本实验围绕社交用户发布的文章做了详尽的分析,通过分析能得到用户群体年龄分布,性别分布,地理位置分布,以及热门话题的热度。
SaaS 模式云数据仓库必修课
本课程由阿里云开发者社区和阿里云大数据团队共同出品,是SaaS模式云原生数据仓库领导者MaxCompute核心课程。本课程由阿里云资深产品和技术专家们从概念到方法,从场景到实践,体系化的将阿里巴巴飞天大数据平台10多年的经过验证的方法与实践深入浅出的讲给开发者们。帮助大数据开发者快速了解并掌握SaaS模式的云原生的数据仓库,助力开发者学习了解先进的技术栈,并能在实际业务中敏捷的进行大数据分析,赋能企业业务。 通过本课程可以了解SaaS模式云原生数据仓库领导者MaxCompute核心功能及典型适用场景,可应用MaxCompute实现数仓搭建,快速进行大数据分析。适合大数据工程师、大数据分析师 大量数据需要处理、存储和管理,需要搭建数据仓库?学它! 没有足够人员和经验来运维大数据平台,不想自建IDC买机器,需要免运维的大数据平台?会SQL就等于会大数据?学它! 想知道大数据用得对不对,想用更少的钱得到持续演进的数仓能力?获得极致弹性的计算资源和更好的性能,以及持续保护数据安全的生产环境?学它! 想要获得灵活的分析能力,快速洞察数据规律特征?想要兼得数据湖的灵活性与数据仓库的成长性?学它! 出品人:阿里云大数据产品及研发团队专家 产品 MaxCompute 官网 https://www.aliyun.com/product/odps 
相关文章
|
2天前
|
机器学习/深度学习 数据可视化 大数据
机器学习与大数据分析的结合:智能决策的新引擎
机器学习与大数据分析的结合:智能决策的新引擎
37 15
|
8天前
|
SQL 分布式计算 DataWorks
DataWorks产品测评|基于DataWorks和MaxCompute产品组合实现用户画像分析
本文介绍了如何使用DataWorks和MaxCompute产品组合实现用户画像分析。首先,通过阿里云官网开通DataWorks服务并创建资源组,接着创建MaxCompute项目和数据源。随后,利用DataWorks的数据集成和数据开发模块,将业务数据同步至MaxCompute,并通过ODPS SQL完成用户画像的数据加工,最终将结果写入`ads_user_info_1d`表。文章详细记录了每一步的操作过程,包括任务开发、运行、运维操作和资源释放,帮助读者顺利完成用户画像分析。此外,还指出了文档中的一些不一致之处,并提供了相应的解决方法。
|
6天前
|
分布式计算 DataWorks 搜索推荐
用户画像分析(MaxCompute简化版)
通过本教程,您可以了解如何使用DataWorks和MaxCompute产品组合进行数仓开发与分析,并通过案例体验DataWorks数据集成、数据开发和运维中心模块的相关能力。
40 4
|
26天前
|
机器学习/深度学习 存储 大数据
在大数据时代,高维数据处理成为难题,主成分分析(PCA)作为一种有效的数据降维技术,通过线性变换将数据投影到新的坐标系
在大数据时代,高维数据处理成为难题,主成分分析(PCA)作为一种有效的数据降维技术,通过线性变换将数据投影到新的坐标系,保留最大方差信息,实现数据压缩、去噪及可视化。本文详解PCA原理、步骤及其Python实现,探讨其在图像压缩、特征提取等领域的应用,并指出使用时的注意事项,旨在帮助读者掌握这一强大工具。
63 4
|
27天前
|
关系型数据库 分布式数据库 数据库
PolarDB 以其出色的性能和可扩展性,成为大数据分析的重要工具
在数字化时代,企业面对海量数据的挑战,PolarDB 以其出色的性能和可扩展性,成为大数据分析的重要工具。它不仅支持高速数据读写,还通过数据分区、索引优化等策略提升分析效率,适用于电商、金融等多个行业,助力企业精准决策。
34 4
|
27天前
|
机器学习/深度学习 分布式计算 算法
【大数据分析&机器学习】分布式机器学习
本文主要介绍分布式机器学习基础知识,并介绍主流的分布式机器学习框架,结合实例介绍一些机器学习算法。
180 5
|
1月前
|
存储 机器学习/深度学习 大数据
量子计算与大数据:处理海量信息的新方法
量子计算作为革命性的计算范式,凭借量子比特和量子门的独特优势,展现出在大数据处理中的巨大潜力。本文探讨了量子计算的基本原理、在大数据处理中的应用及面临的挑战与前景,展望了其在金融、医疗和物流等领域的广泛应用。
|
2月前
|
存储 机器学习/深度学习 分布式计算
大数据技术——解锁数据的力量,引领未来趋势
【10月更文挑战第5天】大数据技术——解锁数据的力量,引领未来趋势
|
1月前
|
存储 分布式计算 数据挖掘
数据架构 ODPS 是什么?
数据架构 ODPS 是什么?
295 7
|
1月前
|
存储 分布式计算 大数据
大数据 优化数据读取
【11月更文挑战第4天】
46 2