Dave Hay commented on my post How Many Attributes Do I Have? Dave notes that there is a difference between me and the roles that I play. This is an important point that I struggled with previously. Dave states "most of the examples are attributes of my role as a customer", meaning the examples I provided in my post.
"Role" is a term that gets bandied around a lot in data modeling. In my previous post on Role vs. Relationship I argued that roles really refer to certain kinds of relationships. However, Dave's point is one that I have heard on a lot of occasions and has to be taken seriously.
Let's state the question this way: is the attribute Customer Lifetime Value to Hardbitten Liquors an attribute of me, or an attribute of my role as a customer of Hardbitten Liquors? And if the latter, just what do we mean by "role".
There is no doubt that I am an instance of a concept. The concept is human being. Further, Customer Lifetime Value to Hardbitten Liquors can be predicated of me, strongly suggesting it is an attribute I possess.
But now let us think of the role that is being suggested in this discussion. What is it? Is this role "Customer of Hardbitten Liquors"? If so, I would argue that this is a relationship between me and Hardbitten Liquors. And if an entity type has attributes, and relationships do not, then we cannot say that a role has any attributes.
But suppose Dave is right and the role does have attributes. It will have to be an entity of some kind. What other thing could the role be - apart from "human being". There is a possibility. Suppose I only ever bought one bottle of Grandpa's Tipple from Hardbitten Liquors. Then, my entire relationship with Hardbitten Liquors could be encompassed by this one event - the purchase of this one bottle. Now, Purchase is an entity type, albeit non-material, so it can at least be a candidate for the role.
But can Purchase really be the same as role? I do not think that an event can have an attribute such as Customer Lifetime Value to Hardbitten Liquors, which really refers to the individual customer. And I do not think this can be true of any aggregate of instances of Purchase events either, supposing, for instance, that I buy one bottle of Grandpa's Tipple every week.