...
...
...
...
...
...
Meaning of the word "Attribute"
Literally, the word "attribute" is a noun and means a quality or characteristic that someone or something has. For example, a person can have a name, address, mobile number and weight, among others. All these are attributes of a person.
In computing , an attribute is a specification that defines a property of an object, element, or file. It may also. For clarity, attributes should more correctly be considered metadata. (with reference to Java Programming Language), the term "attribute" is used to refer to (a) variable(s) exposed in a Java class and the columns in a database table. An attribute is generally a property of a property. However, in actual usage,an attribute refers to or set the specific values for a given instance An attribute of an object usually consists of a name and a value; of an element, a type or class name; of a file, a name and extension.
- Each named attribute has an associated set of rules called operations: one doesn't sum characters or manipulate and process an integer array as an image object—one doesn't process text as type floating point (decimal numbers).
- It follows that an object definition can be extended by imposing data typing: a representation format, a default value, and legal operations (rules) and restrictions are all potentially involved in defining an attribute, or conversely, may be spoken of as attributes of that object's type.
For example, in computer graphics, line objects can have attributes such as thickness (with real values), color (with descriptive values such as brown or green or values defined in a certain color model, such as RGB), dashing attributes, etc. A circle object can be defined in similar attributes plus an origin and radius. In reference to computer systems.
In OpenMRS, the meaning attribute is of no difference to its literal meaning. Every attribute corresponds to a
For example, considering the Java class below,
Code Block | ||||
---|---|---|---|---|
| ||||
public class MyClass {
int x = 5;
String y = "three";
}
|
we can deduce that MyClass
has attributes x
and y
which can be included in the database table as columns.
In core OpenMRS, attributes exist and every attribute corresponds to an AttributeType, which defines, among other things, whether it is required, whether it may repeat, and how it is serialized and deserialized for storage. These attribute types are intended for use in cases that would involve adding custom columns to the base table in a less generic system.
For example:
- Visit has VisitAttributes that are defined by VisitAttributeTypes
- Person has Person has PersonAttributes that are defined by PersonAttributeTypes.
- Concept has ConceptAttributes that are defined by ConceptAttributeTypes
- Provider has ProviderAttributes that are defined by ProviderAttributeTypes
- Location has LocationAttributes that are defined by LocationAttributeTypes
resorces
https://en.wikipedia.org/wiki/Attribute_(computing)
.
However core code does not refer to a specific OpenMRS attribute, because any attribute of a table needed by core should instead be added to the core data model directly.
The need for improvement of Attributes and Atribute types in OpenMRS started when @dkayiwa noticed the extensibility of the EAV pattern in our obs table along with several requests from implementations for implementation specific adjustments to the data model. For example, Tanzania wanted to record the “ten cell” for each person – a convention specific to that region for identifying clusters of homes. He thought, could we apply the extensibility of obs to our person object. So, we created a person_attribute table along with an person_attribute_type table to define custom “attributes” of person that would be an alternative to adding a new column to the person table (since not everyone wants or needs a “ten cell” attribute for person).
Thereafter, we decided to created more tables in OpenMRS where we add “_attribute
” to a domain object (like Person, Visit, Location, among others). This approach of adding an x_attribute
table (where x represents a domain object) has been repeated for several other domain objects (like Person, Visit, Location, Provider and Concept) for the same purpose. Actually, the attribute definitions are stored in x_attribute_type
and the actual values for each x
are stored in x_attribute.
If you take a look at the om.rs/dm data model browser, you can see these attribute tables as an example. The purpose is to allow local extensions to the data model without having to modify the shared (core) data model.
references
- https://dictionary.cambridge.org/dictionary/english/attribute
- OpenMRS Data Model
- https://wiki.openmrs.org/display/projects/Improved+Person+Attribute+Types