Relationship Scenario (Many to Many Relationship)
Video: https://www.youtube.com/watch?v=nzmk1hrYYtQ
Relationship scenario (Many to Many Relationship)
- Trainer can train on multiple Courses
- E.g.- T1 Trainer trains on C1 and C2 Courses
- Course can be handled by multiple Trainers
- E.g.- C3 Course is handled by T3, T4 and T5trainers
data:image/s3,"s3://crabby-images/2b1eb/2b1eb5e0d4200c7cd67dc580c3a13a5224becea9" alt=""
- Many to Many Relationship requires a new table (
TrainsOnCourse
) for storing the collections that are selected in the list box - Create a new Model Trainer
data:image/s3,"s3://crabby-images/32f99/32f9916e1a2d1eb29a621b27089a8adf7bef5314" alt=""
- Execute the command "Add-Migration" in package manager console and update the database for adding the trainer table in the SQL Server database
data:image/s3,"s3://crabby-images/c8ff1/c8ff1e981cdff912e19306992e4eda8c7efc6c35" alt=""
- Build the solution and create a new model for "
TrainsOnCourse
" for storing the collections selected in the list box.
data:image/s3,"s3://crabby-images/e6a8f/e6a8fbed5606fd58cf85d6fd85ff7cf28d904be8" alt=""
- Add a
DBSet
entity property for the TrainsOnCourse
in the DBContext
class.
data:image/s3,"s3://crabby-images/79b01/79b0108aa18225c9befa4004b570dc0ff45d9d1d" alt=""
- Modify the Trainer model for adding navigational property and for saving the collection items selected in the
listbox
.
data:image/s3,"s3://crabby-images/2264a/2264aeaf6e066687424f03fc4ea6622eeb28736e" alt=""
- Build the solution and execute the "Add-Migration" command in the package manager console for adding the new table "
TrainsOnCourse
". - Update the database for running the migration file in the SQL Server by executing the "update-database" command in package manager console.
data:image/s3,"s3://crabby-images/19c01/19c01a0a60fd7d0162a0214e4d49fb06c952068a" alt=""
- Open the SQL Server and new table "
TrainsOnCourse
" table should be created with 2 foreign keys.
data:image/s3,"s3://crabby-images/eb031/eb03147e2da67e99c46e6d3d5986dd3a212b7bd2" alt=""
- Add a new Controller "
Trainer
". - Select the "Tranier.cs" model and "
DNSCContext
".
data:image/s3,"s3://crabby-images/33afc/33afc210194f3ac2a51af4f91f0edd82f1c0db9a" alt=""
- Modify the Create Action method to add multiselect list values to be populated from the
Course
table from the database.
data:image/s3,"s3://crabby-images/1da6a/1da6af0f61f23c65b7c874eb273ac66fc099433d" alt=""
- Add a
ListBoxControl
in "Create.cshtml" view page in Trainer folder.
- Run the application and goto "Trainer/Create" Actionmethod by entering in the url.
- We should be able to see the ListBox with set of values
data:image/s3,"s3://crabby-images/cc1bc/cc1bcf9b80384c17416278e9464514fb85f92304" alt=""
- Save the collection list items to the database.
- Modify the
HTTPPost
create action method to save the selected items.
data:image/s3,"s3://crabby-images/a18be/a18bee0a01a84dfd652859dd20d1f24943041324" alt=""
- Modify the Edit Action method in the Trainer controller for handling
Listbox
control.
data:image/s3,"s3://crabby-images/f3a06/f3a06dd070ba79a4f30b36e5c76888084a07e494" alt=""
- Open the "Edit.cshtml" view page of trainer and add the
ListBox
control.
data:image/s3,"s3://crabby-images/cb46c/cb46c2115f572e45cfdf80e0d347871303613c45" alt=""
- Open the
HttpPost
Edit Action method of the Trainer controller and perform the required operations.
data:image/s3,"s3://crabby-images/ed4f0/ed4f03dc3fdb951b89e6df28dc2cb12598d0f142" alt=""
- Test the application with
listbox
values selected with create and edit operations.