Book Shop - svetlilaloli/EntityFramework-SoftUni GitHub Wiki
Exercises: Advanced Querying
BookShop System
1. Book Shop Database
You must create a database for a book shop system.
Constraints
Your namespaces should be:
- BookShop β for your StartUp class
- BookShop.Data β for your DbContext
- BookShop.Models β for your models
- BookShop.Models.Enums β for your models
Your models should be:
- BookShopContext β your DbContext
- Author:
- AuthorId
- FirstName (up to 50 characters, unicode, not required)
- LastName (up to 50 characters, unicode)
- Book:
- BookId
- Title (up to 50 characters, unicode)
- Description (up to 1000 characters, unicode)
- ReleaseDate (not required)
- Copies (an integer)
- Price
- EditionType β enum (Normal, Promo, Gold)
- AgeRestriction β enum (Minor, Teen, Adult)
- Author
- BookCategories
- Category:
- CategoryId
- Name (up to 50 characters, unicode)
- CategoryBooks
- BookCategory β mapping class
For the following tasks, you will be creating methods that accept a BookShopContext as a parameter and use it to run some queries. Create those methods inside your StartUp class and upload your whole solution to Judge.
2. Age Restriction
NOTE: You will need method public static string GetBooksByAgeRestriction(BookShopContext context, string command)
and public StartUp
class.
Return in a single string all book titles, each on a new line, that have age restriction, equal to the given command. Order the titles alphabetically.
Read input from the console in your main method, and call your method with the necessary arguments. Print the returned string to the console. Ignore the casing of the input.
Example
Input | Output |
---|---|
miNor | A Confederacy of DuncesA Farewell to ArmsA Handful of Dust⦠|
teEN | A Passage to IndiaA Scanner DarklyA Swiftly Tilting Planet⦠|
3. Golden Books
NOTE: You will need method public static string GetGoldenBooks(BookShopContext context)
and public StartUp
class.
Return in a single string with titles of the golden edition books that have less than 5000 copies, each on a new line. Order them by book id ascending.
Call the GetGoldenBooks(BookShopContext context)
method in your Main()
and print the returned string to the console.
Example
Output |
---|
Lilies of the FieldLook HomewardThe Mirror Crack'd from Side to Side⦠|
4. Books by Price
NOTE: You will need method public static string GetBooksByPrice(BookShopContext context)
and public StartUp
class.
Return in a single string all titles and prices of books with price higher than 40, each on a new row in the format given below. Order them by price descending.
Example
Output |
---|
O Pioneers! - $49.90That Hideous Strength - $48.63A Handful of Dust - $48.63β¦ |
5. Not Released In
NOTE: You will need method public static string GetBooksNotReleasedIn(BookShopContext context, int year)
and public StartUp
class.
Return in a single string all titles of books that are NOT released on a given year. Order them by book id ascending.
Example
Input | Output |
---|---|
2000 | AbsalomNectar in a SieveNine Coaches Waiting⦠|
1998 | The Needle's EyeNo Country for Old MenNo Highway⦠|
6. Book Titles by Category
NOTE: You will need method public static string GetBooksByCategory(BookShopContext context, string input)
and public StartUp
class.
Return in a single string the titles of books by a given list of categories. The list of categories will be given in a single line separated with one or more spaces. Ignore casing. Order by title alphabetically.
Example
Input | Output |
---|---|
horror mystery drama | A Fanatic HeartA Farewell to ArmsA Glass of Blessings⦠|
7. Released Before Date
NOTE: You will need method public static string GetBooksReleasedBefore(BookShopContext context, string date)
and public StartUp
class.
Return the title, edition type and price of all books that are released before a given date. The date will be a string in format dd-MM-yyyy.
Return all of the rows in a single string, ordered by release date descending.
Example
Input | Output |
---|---|
12-04-1992 | If I Forget Thee Jerusalem - Gold - $33.21Oh! To be in England - Normal - $46.67The Monkey's Raincoat - Normal - $46.93β¦ |
30-12-1989 | A Fanatic Heart - Normal - $9.41The Curious Incident of the Dog in the Night-Time - Normal - $23.41The Other Side of Silence - Gold - $46.26β¦ |
8. Author Search
NOTE: You will need method public static string GetAuthorNamesEndingIn(BookShopContext context, string input)
and public StartUp
class.
Return the full names of authors, whose first name ends with a given string.
Return all names in a single string, each on a new row, ordered alphabetically.
Example
Input | Output |
---|---|
e | George PowellJane Ortiz |
dy | Randy Morales |
9. Book Search
NOTE: You will need method public static string GetBookTitlesContaining(BookShopContext context, string input)
and public StartUp
class.
Return the titles of book, which contain a given string. Ignore casing.
Return all titles in a single string, each on a new row, ordered alphabetically.
Example
Input | Output |
---|---|
sK | A Catskill EagleThe Daffodil SkyThe Skull Beneath the Skin |
WOR | Great Work of TimeTerrible Swift Sword |
10. Book Search by Author
NOTE: You will need method public static string GetBooksByAuthor(BookShopContext context, string input)
and public StartUp
class.
Return all titles of books and their authorsβ names for books, which are written by authors whose last names start with the given string.
Return a single string with each title on a new row. Ignore casing. Order by book id ascending.
Example
Input | Output |
---|---|
R | The Heart Is Deceitful Above All Things (Bozhidara Rysinova)His Dark Materials (Bozhidara Rysinova)The Heart Is a Lonely Hunter (Bozhidara Rysinova)β¦ |
po | Postern of Fate (Stanko Popov)Precious Bane (Stanko Popov)The Proper Study (Stanko Popov)β¦ |
11. Count Books
NOTE: You will need method public static int CountBooks(BookShopContext context, int lengthCheck)
and public StartUp
class.
Return the number of books, which have a title longer than the number given as an input.
Example
Input | Output | Comments |
---|---|---|
12 | 169 | There are 169 books with longer title than 12 symbols |
40 | 2 | There are 2 books with longer title than 40 symbols |
12. Total Book Copies
NOTE: You will need method public static string CountCopiesByAuthor(BookShopContext context)
and public StartUp
class.
Return the total number of book copies for each author. Order the results descending by total book copies.
Return all results in a single string, each on a new line.
Example
Output |
---|
Stanko Popov - 117778Lyubov Ivanova - 107391Jane Ortiz β 103673β¦ |
13. Profit by Category
NOTE: You will need method public static string GetTotalProfitByCategory(BookShopContext context)
and public StartUp
class.
Return the total profit of all books by category. Profit for a book can be calculated by multiplying its number of copies by the price per single book. Order the results by descending by total profit for category and ascending by category name.
Example
Output |
---|
Art $6428917.79Fantasy $5291439.71Adventure $5153920.77Children's $4809746.22β¦ |
14. Most Recent Books
NOTE: You will need method public static string GetMostRecentBooks(BookShopContext context)
and public StartUp
class.
Get the most recent books by categories. The categories should be ordered by name alphabetically. Only take the top 3 most recent books from each category - ordered by release date (descending). Select and print the category name, and for each book β its title and release year.
Example
Output |
---|
--ActionBrandy ofthe Damned (2015)Bonjour Tristesse (2013)By Grand Central Station I Sat Down and Wept (2010)--AdventureThe Cricket on the Hearth (2013)Dance Dance Dance (2002)Cover Her Face (2000)β¦ |
15. Increase Prices
NOTE: You will need method public static void IncreasePrices(BookShopContext context)
and public StartUp
class.
Increase the prices of all books released before 2010 by 5.
16. Remove Books
NOTE: You will need method public static int RemoveBooks(BookShopContext context)
and public StartUp
class.
Remove all books, which have less than 4200 copies. Return an int - the number of books that were deleted from the database.
Example
Output |
---|
34 |