Display data from a table in ASP.Net Web App

From TRCCompSci - AQA Computer Science
Revision as of 15:10, 9 January 2025 by Admin (talk | contribs) (Getting the data)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to: navigation, search

Just for this example we will be retrieving the details from the user table, so I created this class to store each record, it should be inside the subclass of `PageModel` :

public class User
{
    public string username { get; set; }
    public string password { get; set; }
    public int status { get; set; }
}

Next I created a list of User to store the retrieved data, it should be inside the subclass of `PageModel`:

public static List<User> users = new List<User>();

You need to have a local webserver running with an installation of MySQL & PHP. I have used the USBWebServer from your SQL lessons. I have also created this connection string. The string below includes the name of the database, mine is just called `test`. The string should be inside the subclass of `PageModel`:

string connection = "server=localhost;user=root;database=test;port=3306;password=usbw;";

Finally I created this method to get the connection, it should be inside the subclass of `PageModel`:

        public MySqlConnection GetConnection 
        {
            get
            {
                return new MySqlConnection(connection);
            }
        }

Getting the data

Now, in the OnGet method I have added the following code:

    users.Clear(); // clear users before a load or reload

    using var connection = GetConnection; // this gets the connection

    connection.Open(); // you must open the connection
            
    using var Command = new MySqlCommand("SELECT * FROM test;", connection ); // you can add your SQL into a command
    using var reader = Command.ExecuteReader(); // you execute the query
    while (reader.Read())
    {
         User temp = new User(); // create user
         temp.username = reader.GetString(0);
         temp.password = reader.GetString(1);
         temp.status = reader.GetInt32(2);
         users.Add(temp); // add user to list
    }

Remember, here `test` in the SQL refers to the table name, so if you have a different table name you must change the SQL. To show the data in your page go back to the HTML code for the page and add:

		@foreach (var u in IndexModel.users)
		{
			<table class="table">
				<thead>
					<tr class="bg-primary">
						<th>User</th>
						<th>Password</th>
						<th>Status</th>

					</tr>
				</thead>
				<tbody>

					<tr>
						<td class="bg-info">@u.username</td>
						<td class="bg-info">@u.password</td>
						<td class="bg-info">@u.status</td>

					</tr>
	
				</tbody>
			</table>
		}