Как мне реализовать IDisposible в этом контексте?

Я использую Entity Framework 4 вместе с MSSQL для хранения и доступа к данным в моем приложении Windows Forms.

Вот пример класса, который я использую для доступа к данным:

public class StudentRepository : IDisposable
{
    ColegioDBEntities db = new ColegioDBEntities();

    public IQueryable<Student> FindAllStudents()
    {
        return db.Students;
    }

    public Student FindStudent(int id)
    {
        return db.Students.SingleOrDefault(c => c.StudentId == id);
    }

    public void Add(Student Student)
    {
        db.AddToStudents(Student);
    }

    public void Save()
    {
        db.SaveChanges();
    }

    public void Dispose()
    {
        db.Dispose();
    }
}

А вот пример как я его использую.

    private void btnLogin_Click(object sender, EventArgs e)
    {
        UserRepository repo = new UserRepository();
        var result = repo.FindAllUsers().Where(u => u.Username == txtUsername.Text && u.Password == txtPassword.Text);
        if (result.Count() > 0)
        {
            MainForm form = new MainForm(txtUsername.Text);
            form.Show();
            this.Hide();
        }
        else
        {
            MessageBox.Show("Usuario y/o contraseña incorrecta.",
            "Acceso Denegado",
            MessageBoxButtons.OK,
            MessageBoxIcon.Stop,
            MessageBoxDefaultButton.Button1);
            txtUsername.Focus();
            txtPassword.Focus();
        }
    }

Кто-то предложил мне использовать IDisposable для правильной «очистки» соединения, но я не знаю, как это реализовать.

Есть предложения? Спасибо за ваше время.

5
задан 13 February 2011 в 15:54
поделиться