
The variables used in the program are given below:
- connectionStringBuilder: an instance of the SqlConnectionStringBuilder class used to create a connection string to the productDB
database . - connectionString: a string that holds the connection string to the database.
- connection: an instance of the SqlConnection class used to connect to the database.
- query: a LINQ query that selects all the products in the database and sorts them by units on hand in ascending order.
- minUnitsOnHand: an integer variable that holds the minimum units on hand specified by the user.
- hasMin: a boolean variable that indicates whether a minimum number of units on hand was specified by the user.
- maxUnitsOnHand: an integer variable that holds the maximum units on hand specified by the user.
- hasMax: a boolean variable that indicates whether a maximum number of units on hand was specified by the user.
The methods used in the program are as follows:
- The SqlConnectionStringBuilder constructor is used to create a connection string to the database.
- The SqlConnection constructor, which creates a new SqlConnection object that can be used to connect to the database.
- The SqlCommand constructor creates a new SqlCommand object that can be used to execute a query against the database.
- The ExecuteReader method of the SqlCommand class is used to execute the query and return a SqlDataReader object that can be used to read the results.
- The Where method of the IQueryable interface is used to filter the data based on a specified condition.
- The TryParse method of the int class is used to convert user input from a string to an integer.
- The Console.WriteLine method, which is used to display information to the user in the console window.
- The Console.ReadLine method, which is used to read user input from the console window.
Program Description:
To write an application that connects to productDB database.
Steps to create an application that connects to a database, sorts, and searches data using LINQ and SQL:
- Create a new C# console application project in Visual Studio.
- Add a reference to the System.Data.SqlClient and System.Linq namespaces.
- Create a connection string to the productDB database using SqlConnectionStringBuilder.
- Create a SqlConnection object and open the connection to the database.
- Create a LINQ query to select all the products in the database and sort them by units on hand in ascending order. You can use the OrderBy method in LINQ to sort the data.
- Execute the query using the SqlCommand object and read the data using the SqlDataReader object.
- Display the data to the user.
- Prompt the user to enter a minimum and/or maximum number of units on hand.
- Modify the LINQ query to filter the products based on the user's input. You can use the Where method in LINQ to filter the data.
- Execute the modified query and display the filtered data to the user.
- Close the SqlDataReader and SqlConnection objects.
Program:
using System; using System.Data.SqlClient; using System.Linq; namespace ProductUnitsOnHandSearch { class Program { static void Main(string[] args) { // Create connection string to the productDB database var connectionStringBuilder = new SqlConnectionStringBuilder { DataSource = "your_server_name", // Replace with your actual database name InitialCatalog = "productDB", IntegratedSecurity = true }; string connectionString = connectionStringBuilder.ToString(); // Create SqlConnection object and open connection using (SqlConnection connection = new SqlConnection(connectionString)) { connection.Open(); // Create LINQ query to select all products and sort by units on hand in ascending order var query = from p in db.Products orderby p.UnitsOnHand ascending select p; // Execute query and read data using (SqlCommand command = new SqlCommand(query.ToString(), connection)) { using (SqlDataReader reader = command.ExecuteReader()) { // Display all products Console.WriteLine("All Products:"); Console.WriteLine("--------------"); while (reader.Read()) { Console.WriteLine("{0}: {1} units on hand", reader["ProductName"], reader["UnitsOnHand"]); } Console.WriteLine(); } } // Prompt user for minimum and maximum units on hand Console.Write("Enter minimum units on hand (or leave blank for no minimum): "); string minInput = Console.ReadLine(); int minUnitsOnHand; bool hasMin = int.TryParse(minInput, out minUnitsOnHand); Console.Write("Enter maximum units on hand (or leave blank for no maximum): "); string maxInput = Console.ReadLine(); int maxUnitsOnHand; bool hasMax = int.TryParse(maxInput, out maxUnitsOnHand); // Modify query to filter by units on hand based on user input if (hasMin) { query = query.Where(p => p.UnitsOnHand >= minUnitsOnHand); } if (hasMax) { query = query.Where(p => p.UnitsOnHand <= maxUnitsOnHand); } // Execute modified query and display filtered products using (SqlCommand command = new SqlCommand(query.ToString(), connection)) { using (SqlDataReader reader = command.ExecuteReader()) { Console.WriteLine("Filtered Products:"); Console.WriteLine("------------------"); while (reader.Read()) { Console.WriteLine("{0}: {1} units on hand", reader["ProductName"], reader["UnitsOnHand"]); } } } } Console.ReadLine(); } } }
Explanation:
The program is a console application that connects to a database called productDB and displays information about the products in the database. The program uses LINQ and SQL to interact with the database and allows the user to search for products with more units on hand than a specified amount or fewer units on hand than a specified amount.
When the program starts, it creates a connection string to the productDB database and opens a connection to the database using the SqlConnection and SqlCommand classes. The program then executes a LINQ query to select all the products in the database and sorts them by units on hand in ascending order.
The program then prompts the user to enter a minimum unit on hand and a maximum unit on hand. If the user enters a valid integer for the minimum or maximum units on hand, the program filters the results using the Where method of the IQueryable interface. If the user does not enter a value for the minimum or maximum units on hand, the program skips that filter.
Finally, the program loops through the results and displays the product ID, name, and units on hand for each product that matches the user's search criteria. If no products match the criteria, the program displays a message indicating that no results were found. The user can then exit the program or search for products again.
SAMPLE OUTPUT:
Enter minimum units on hand (press enter to skip): 50 Enter maximum units on hand (press enter to skip): 100 Products with units on hand between 50 and 100: ---------------------------------------------- Product ID: 2 Name: Rechargeable Lamp Units on hand: 75 Product ID: 4 Name: Smart watch Units on hand: 80 Do you want to search again? (Y/N) y Enter minimum units on hand (press enter to skip): Enter maximum units on hand (press enter to skip): 200 Products with units on hand between 0 and 200: ---------------------------------------------- Product ID: 1 Name: Wireless Earbuds Units on hand: 120 Product ID: 3 Name:Head phones Units on hand: 150 Do you want to search again? (Y/N) n Press any key to exit...

Want to see the full answer?
Check out a sample textbook solution
Chapter 14 Solutions
Starting Out With Visual C# (5th Edition)
- using r language in an accelerated failure test, components are operated under extreme conditions so that a substantial number will fail in a rather short time. in such a test involving two types of microships 600 chips manufactured by an existing process were tested and 125 of them failed then 800 chips manufactured by a new process were tested and 130 of them failed what is the 90%confidence interval for the difference between the proportions of failure for chips manufactured by two processes? using r languagearrow_forwardI want a picture of the tools and the pictures used Cisco Packet Tracer Smart Home Automation:o Connect a temperature sensor and a fan to a home gateway.o Configure the home gateway so that the fan is activated when the temperature exceedsa set threshold (e.g., 30°C).2. WiFi Network Configuration:o Set up a wireless LAN with a unique SSID.o Enable WPA2 encryption to secure the WiFi network.o Implement MAC address filtering to allow only specific clients to connect.3. WLC Configuration:o Deploy at least two wireless access points connected to a Wireless LAN Controller(WLC).o Configure the WLC to manage the APs, broadcast the configured SSID, and applyconsistent security settings across all APs.arrow_forwardA. What will be printed executing the code above?B. What is the simplest way to set a variable of the class Full_Date to January 26 2020?C. Are there any empty constructors in this class Full_Date?a. If there is(are) in which code line(s)?b. If there is not, how would an empty constructor be? (create the code lines for it)D. Can the command std::cout << d1.m << std::endl; be included after line 28 withoutcausing an error?a. If it can, what will be printed?b. If it cannot, how could this command be fixed?arrow_forward
- Cisco Packet Tracer Smart Home Automation:o Connect a temperature sensor and a fan to a home gateway.o Configure the home gateway so that the fan is activated when the temperature exceedsa set threshold (e.g., 30°C).2. WiFi Network Configuration:o Set up a wireless LAN with a unique SSID.o Enable WPA2 encryption to secure the WiFi network.o Implement MAC address filtering to allow only specific clients to connect.3. WLC Configuration:o Deploy at least two wireless access points connected to a Wireless LAN Controller(WLC).o Configure the WLC to manage the APs, broadcast the configured SSID, and applyconsistent security settings across all APs.arrow_forwardTransform the TM below that accepts words over the alphabet Σ= {a, b} with an even number of a's and b's in order that the output tape head is positioned over the first letter of the input, if the word is accepted, and all letters a should be replaced by the letter x. For example, for the input aabbaa the tape and head at the end should be: [x]xbbxx z/z,R b/b,R F ① a/a,R b/b,R a/a, R a/a,R b/b.R K a/a,R L b/b,Rarrow_forwardGiven the C++ code below, create a TM that performs the same operation, i.e., given an input over the alphabet Σ= {a, b} it prints the number of letters b in binary. 1 #include 2 #include 3 4- int main() { std::cout > str; for (char c : str) { if (c == 'b') count++; 5 std::string str; 6 int count = 0; 7 char buffer [1000]; 8 9 10 11- 12 13 14 } 15 16- 17 18 19 } 20 21 22} std::string binary while (count > 0) { binary = std::to_string(count % 2) + binary; count /= 2; std::cout << binary << std::endl; return 0;arrow_forward
- Considering the CFG described below, answer the following questions. Σ = {a, b} • NT = {S} Productions: P1 S⇒aSa P2 P3 SbSb S⇒ a P4 S⇒ b A. List one sequence of productions that can accept the word abaaaba; B. Give three 5-letter words that can be accepted by this CFG; C. Create a Pushdown automaton capable of accepting the language accepted by this CFG.arrow_forwardGiven the FSA below, answer the following questions. b 1 3 a a b b с 2 A. Write a RegEx that is equivalent to this FSA as it is; B. Write a RegEx that is equivalent to this FSA removing the states and edges corresponding to the letter c. Note: To both items feel free to use any method you want, including analyzing which words are accepted by the FSA, to generate your RegEx.arrow_forward3) Finite State Automata Given the FSA below, answer the following questions. a b a b 0 1 2 b b 3 A. Give three 4-letter words that can be accepted by this FSA; B. Give three 4-letter words that cannot be accepted by this FSA; C. How could you describe the words accepted by this FSA? D. Is this FSA deterministic or non-deterministic?arrow_forward
- Considering the TM below, answer the following questions. a/x,R €/E,L €/E,R €/E,L x/E,R c/c,R b/E.L c/c,L x/x,R I J K L M F b/E.L D A. Give three 4-letter words that can be accepted by this TM; B. Give three 4-letter words that cannot be accepted by this TM; C. How could you describe the words accepted by this TM? D. What is the alphabet of the language accepted by this TM?arrow_forwardWhat is the generator? Explain motor generator motorarrow_forwardThis battle room is focused on entry level tasks for a network analyst where you will be given trials and reconnaissance, sensor tuning, log aggregation, SIEM queries, and network analysis. For this week’s project, complete the following tasks: From your Project Ares portal, LOG IN Click on LAUNCH GAME. Select the region NORTH AMERICA Click on Battle School Under the BATTLE SCHOOL pop-up window, click on START TRAINING. Under the BATTLE ROOMS tile, click on ENTER. Under the NETWORK ANALYST tile, click on PLAY. Wait for the Battle Room to load. While loading, the BATTLE ROOM button will display red. Once the Battle Room is loaded, the BATTLE ROOM button will turn yellow and the center of the disk display will indicate CONNECTED. Click on the BATTLE ROOM button to enter the Battle Room. Below the TASKS folder, make sure you click on INSTRUCTIONS to download the Network Analyst Fundamentals material. In the Battle Room, under the TASKS menu select task INTRUSION DETECTION. Complete…arrow_forward
- Programming with Microsoft Visual Basic 2017Computer ScienceISBN:9781337102124Author:Diane ZakPublisher:Cengage LearningCOMPREHENSIVE MICROSOFT OFFICE 365 EXCEComputer ScienceISBN:9780357392676Author:FREUND, StevenPublisher:CENGAGE L
- Enhanced Discovering Computers 2017 (Shelly Cashm...Computer ScienceISBN:9781305657458Author:Misty E. Vermaat, Susan L. Sebok, Steven M. Freund, Mark Frydenberg, Jennifer T. CampbellPublisher:Cengage LearningFundamentals of Information SystemsComputer ScienceISBN:9781305082168Author:Ralph Stair, George ReynoldsPublisher:Cengage LearningNp Ms Office 365/Excel 2016 I NtermedComputer ScienceISBN:9781337508841Author:CareyPublisher:Cengage


