Many-to-one association between Product and Category entities

8 minutes
Share the link to this page
Copied
  Completed
You need to have access to the item to view this lesson.
One-time Fee
$49.99
List Price:  $69.99
You save:  $20
€47.92
List Price:  €67.09
You save:  €19.17
£39.76
List Price:  £55.67
You save:  £15.90
CA$71.86
List Price:  CA$100.61
You save:  CA$28.75
A$79.95
List Price:  A$111.94
You save:  A$31.98
S$67.76
List Price:  S$94.87
You save:  S$27.11
HK$388.87
List Price:  HK$544.46
You save:  HK$155.58
CHF 44.66
List Price:  CHF 62.54
You save:  CHF 17.87
NOK kr565.88
List Price:  NOK kr792.28
You save:  NOK kr226.40
DKK kr357.50
List Price:  DKK kr500.54
You save:  DKK kr143.03
NZ$88.36
List Price:  NZ$123.72
You save:  NZ$35.35
د.إ183.61
List Price:  د.إ257.07
You save:  د.إ73.46
৳5,972.07
List Price:  ৳8,361.37
You save:  ৳2,389.30
₹4,246.46
List Price:  ₹5,945.38
You save:  ₹1,698.92
RM225.35
List Price:  RM315.51
You save:  RM90.16
₦77,461.50
List Price:  ₦108,452.30
You save:  ₦30,990.80
₨13,910.80
List Price:  ₨19,476.23
You save:  ₨5,565.43
฿1,709.72
List Price:  ฿2,393.75
You save:  ฿684.02
₺1,759.33
List Price:  ₺2,463.20
You save:  ₺703.87
B$304.23
List Price:  B$425.95
You save:  B$121.72
R915.31
List Price:  R1,281.50
You save:  R366.19
Лв93.65
List Price:  Лв131.12
You save:  Лв37.46
₩72,306.53
List Price:  ₩101,234.93
You save:  ₩28,928.40
₪182.68
List Price:  ₪255.76
You save:  ₪73.08
₱2,941.16
List Price:  ₱4,117.86
You save:  ₱1,176.70
¥7,821.18
List Price:  ¥10,950.28
You save:  ¥3,129.10
MX$1,003.69
List Price:  MX$1,405.25
You save:  MX$401.55
QR182.18
List Price:  QR255.07
You save:  QR72.89
P690.74
List Price:  P967.09
You save:  P276.35
KSh6,461.20
List Price:  KSh9,046.20
You save:  KSh2,585
E£2,543.65
List Price:  E£3,561.31
You save:  E£1,017.66
ብር6,381.64
List Price:  ብር8,934.81
You save:  ብር2,553.16
Kz45,890.82
List Price:  Kz64,250.82
You save:  Kz18,360
CLP$49,447.60
List Price:  CLP$69,230.60
You save:  CLP$19,783
CN¥364.74
List Price:  CN¥510.67
You save:  CN¥145.92
RD$3,043.26
List Price:  RD$4,260.81
You save:  RD$1,217.54
DA6,741.95
List Price:  DA9,439.27
You save:  DA2,697.32
FJ$115.80
List Price:  FJ$162.13
You save:  FJ$46.33
Q385.07
List Price:  Q539.13
You save:  Q154.06
GY$10,455.79
List Price:  GY$14,638.94
You save:  GY$4,183.15
ISK kr6,955.10
List Price:  ISK kr9,737.70
You save:  ISK kr2,782.60
DH502.98
List Price:  DH704.21
You save:  DH201.23
L918.26
List Price:  L1,285.64
You save:  L367.37
ден2,949.73
List Price:  ден4,129.86
You save:  ден1,180.13
MOP$400.09
List Price:  MOP$560.15
You save:  MOP$160.06
N$920.09
List Price:  N$1,288.20
You save:  N$368.11
C$1,839.03
List Price:  C$2,574.79
You save:  C$735.75
रु6,798.06
List Price:  रु9,517.84
You save:  रु2,719.77
S/186.09
List Price:  S/260.55
You save:  S/74.45
K202.66
List Price:  K283.74
You save:  K81.08
SAR187.79
List Price:  SAR262.92
You save:  SAR75.13
ZK1,383.09
List Price:  ZK1,936.44
You save:  ZK553.34
L238.52
List Price:  L333.95
You save:  L95.43
Kč1,204.37
List Price:  Kč1,686.22
You save:  Kč481.84
Ft19,842.53
List Price:  Ft27,781.13
You save:  Ft7,938.60
SEK kr551.51
List Price:  SEK kr772.16
You save:  SEK kr220.65
ARS$51,075.09
List Price:  ARS$71,509.21
You save:  ARS$20,434.12
Bs345.34
List Price:  Bs483.51
You save:  Bs138.16
COP$217,942.60
List Price:  COP$305,137.08
You save:  COP$87,194.48
₡25,214.88
List Price:  ₡35,302.85
You save:  ₡10,087.97
L1,268.63
List Price:  L1,776.18
You save:  L507.55
₲389,688.96
List Price:  ₲545,595.73
You save:  ₲155,906.76
$U2,236.96
List Price:  $U3,131.93
You save:  $U894.96
zł204.31
List Price:  zł286.05
You save:  zł81.74
Already have an account? Log In

Transcript

To understand the many to one and one to many associations between entities, let's go first create a new entity class called product. So I'm going to right click on the entity package, new class here, call it as product. Press Enter. This is also a plain ordinary Java object. I'm going to have some variables here called private integer product ID, private string product name, it also will have some kind of a quantity per unit. Let's give it a price.

Double unit price. A product also belongs to a category. So the association between a product and category here would be like many products belong to one category. Hence the association is many to one. As a general rule of thumb, if you have a foreign key in a table that is represented using a many to one Association To say that the product has association with a category. Let's create a variable here called category of type category.

Let's also add a constructor here. And then generate getters and setters by going to source menu, generate getters and setters. Select All, say, OK, and let's also add a two string by going to source generate to string and then say, Okay, we got the two string, representing even the category also, in order to map this to a table called products. Let's first add at the rate entity. And then at the rate table, name equals two products. Since we don't have this particular table called products, because of HBM to DDL dot auto equals to update, hibernate will automatically add this table that's imported.

Let's also artists as at the rate ID at the rate generated value. Once again. In the previous case, we'll add the same strategy, which is identity, which means there will be an auto increment added to this particular field. We'll also say that this is mapped to a column whose name is product underscore ID. This is going to be a product name with an underscore. This is going to be a quantity underscore or underscore unit unit underscore price.

And this one is not a column mapping. If you just leave the category without any column mapping, hibernate will automatically assumes that this is a column in your table and it tries to create such a column because we have given HBM to DDL auto but this is not a scalar type, which means there is no data type called category in an RDBMS. So we have to say that this is not a column by itself, but this corresponds to a foreign key called category underscore ID. So we're going to say here at the rate many to one. And then we say, at the rate join column, we say name equals to category underscore ID. What it does is it's going to create a new column called category underscore ID in products table makes it as a foreign key to the primary key of the table corresponding to this category, which is category stable.

Now that we have this product class, we also have to tell in hibernate util that there is another class that hibernate should manage by adding this CFG dot add annotated class entry. So CFG dot add annotated class of product class. Now hibernate is aware that there is another entity class. Now if you run any of the previous programs, hibernate will automatically synchronize the entity classes and the tables It's going to create the products table as well. But to see if this association works, let's go and create a new Java class. Under the programs package, I'm going to call this as x 05 package, called the class as mean.

Also add the main function over here. Let's fullscreen this, delete the to do, and then I'm going to paste this snippets which we used earlier as well, I'm going to import the packages. So we got the session and we have begun the transaction. So I'm going to create a new product object here and then associate that with our existing category called beverages. So first I'll give the category called beverages by typing c one equals to session dot get. And then I type your category class ID is one and then this C one has to be created as a category object.

Let's also create a new product object by typing product, p one equals two new product. Let's give some values to that P one dot set product name of, let's say, p one dot set quantity per unit, let's say 10 boxes into 20 bags. Let's give it a price of let's say for example, eating point zero dollars, ID is automatically generated. But I'm going to say p one dot set category of C one. And now if I come down here and say session dot persist, p one, p one will now be inserted with the primary key value of c one as its category ID. So I'm going to type your system dot out dot print ln, new product saved with ID and then I type your P one dot get product ID.

Save this run the same and you will see that There is a new CREATE TABLE command with ALTER TABLE also here because there is a foreign key being added over here. This is to retrieve the category object. And then we have an insert into products with all these values and say new products here with ID one. Let's go and have a look at the same. So first I go here and refresh this, you will see that there is a products table. I'm going to click on the products here.

So select star from products appears. I click on Run, and you will see that there is a new product ID auto generated ID here, the values have come but importantly category underscore ID is one. And that's because we did an association mapping over here, many to one also brings us other features. For example, if I retrieve a product object based on the ID, the corresponding category also will be retrieved to demonstrate the same Let's take another program. So I go to this package, new class. And then I type your package names six The program name is mean.

Let's also add the main function fullscreen this, get rid of this, I will also add the basic code snippet that we have been using. And now we don't need a transaction this time because we're only going to retrieve the data. So I'm going to type your P one equals to session dot get, and then say product dot class ID of one, that's the newly added product. And p one is going to be a product object, we close the session and then I'm going to type your sis out p one, you will see that the product object comes with not only the data from the products table, but also from the corresponding category table. So if I save this and run the same, you should see that the product along with the category has been returned over here and it says your category ID is one name is beverages description is so on.

So, you can see that it has achieved that by using the joint statement here. So it is Join the products table with the categories table. This kind of retrieval of one entity based on another entity is called as eager fetch, because we only asked for a product object, but hibernate went ahead and brought the corresponding category also. There is also another concept called lazy fetch, where you ask for one entity, even though there are other entities that this entity refers to. hibernate will only fetch the Ask the entity which is called lazy fetch. By default, many to one is an eager fetch and one to many is lazy fit

Sign Up

Share

Share with friends, get 20% off
Invite your friends to LearnDesk learning marketplace. For each purchase they make, you get 20% off (upto $10) on your next purchase.