目录
一、应用程序设计
二、应用程序源码
三、生成效果
前文作者发布了在.NET 6.0 控制台应用中通过EF访问已有数据库,事实上,在.NET 6.0 Windows窗体应用中通过EF访问已有数据库也是一样的。操作方法基本一样,数据库EF模型和上下文都是自动生成的,在这里不再重复叙述,只把应用部分、窗体设计、生成效果分享出来。
一、应用程序设计
设计有一个窗体,dataGridView1显示数据库的数据表blog,textBox1的文本是要追加记录的网址,button1是追加按钮。textBox2的文本是要删除记录的ID,button2是删除按钮。
二、应用程序源码
// .NET 6.0窗体应用访问已有数据库
// .NET 7.0下同样的应用,没有报警,就是数据库不能加载到 dataGridView1
// 对数据库进行追加记录、删除记录操作
namespace _10_10
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
}
/// <summary>
/// 初始化Form1
/// 初始化表格,显示数据表
/// </summary>
private void Form1_Load(object sender, EventArgs e)
{
button1.Text = "追加";
button2.Text = "删除";
label1.Text = "追加的Url:";
label2.Text = "删除的ID:";
button1.Size = new Size(40, 23);
button2.Size = new Size(40, 23);
dataGridView1.AllowUserToAddRows = false;
dataGridView1.AllowUserToDeleteRows = false;
dataGridView1.AllowUserToResizeColumns = false;
dataGridView1.AllowUserToResizeRows = false;
dataGridView1.RowHeadersVisible = false;
dataGridView1.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells;
using var db = new BloggingContext();
dataGridView1.DataSource = db.Blogs.ToList();
}
/// <summary>
/// 追加Add()
/// 无论ID是否连续,都在数据库末尾追加新纪录
/// </summary>
#region 追加
private void button1_Click(object sender, EventArgs e)
{
using var db = new BloggingContext();
if (textBox1.Text != "")
{
db.Blogs.Add(new Blog { Url = textBox1.Text.Trim().ToString() }); //追加记录
db.SaveChanges();
dataGridView1.DataSource = db.Blogs.ToList();
}
else
{
db.Blogs.Add(new Blog { Url = "http://www.hao123.com/" }); //追加记录
db.SaveChanges();
dataGridView1.DataSource = db.Blogs.ToList();
}
}
#endregion 追加
/// <summary>
/// 删除Remove()
/// </summary>
#region 删除记录
private void button2_Click(object sender, EventArgs e)
{
using var db = new BloggingContext();
db.Blogs.Remove(new Blog { BlogId = Convert.ToInt32(textBox2.Text.Trim()) }); //删除记录按ID
db.SaveChanges();
dataGridView1.DataSource = db.Blogs.ToList();
}
#endregion 删除记录
}
}
三、生成效果
困惑的是:.NET 7.0 Windows窗体应用应用同样的程序、同样的操作,却始终不能加载数据库到dataGridView。