gpt4 book ai didi

c# - 错误 - 字段初始值设定项无法引用非静态字段、方法或属性

转载 作者:行者123 更新时间:2023-12-02 22:20:32 24 4
gpt4 key购买 nike

我今天开始学习C#编程中的SQL连接。我尝试了一些基本操作,例如插入、删除等。

我想在另一个项目中尝试同样的事情,但我遇到了问题。因为它向我显示了一个我无法解决的错误:(

错误:

A field initializer cannot reference the non-static field, method, or property 'Artikujt.Form1.con'.

这是我的代码(我刚开始用 SQL 将它与数据库连接)

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;

namespace Artikujt
{
public partial class Form1 : Form
{
SqlConnection con = new SqlConnection(@"Data Source=TALY-PC;Initial Catalog=Katalogi;Integrated Security=True;Pooling=False");
SqlDataAdapter da = new SqlDataAdapter("SELECT * FROM tblArtikujt", con);
DataSet dsl = new DataSet();

public Form1()
{
InitializeComponent();
}
}
}

错误在这段代码中的变量con

SqlDataAdapter da = new SqlDataAdapter("SELECT * FROM tblArtikujt", con);

我在 SQL 中创建了数据库(在 Visual Studio 中)...我还添加了数据源。我做了我以前做过的事情......但它不起作用:(

最佳答案

错误正是它所说的。您不能在 da 的初始化中使用 con,因为它只会在实例创建期间创建。您需要将 con 创建为 static 或将初始化行放入构造函数中。

但是,您可能不应该在实践中这样做,因为您只是要求某人打开一个SqlConnection 并保持打开状态。您可能应该更多地使用 using block 来创建连接,以利用处理模式

静态:

public partial class Form1 : Form
{
static SqlConnection con = new SqlConnection(@"Data Source=TALY-PC;Initial Catalog=Katalogi;Integrated Security=True;Pooling=False");
SqlDataAdapter da = new SqlDataAdapter("SELECT * FROM tblArtikujt", con);
DataSet dsl = new DataSet();


public Form1()
{
InitializeComponent();
}

或者在构造函数中实例化:

public partial class Form1 : Form
{
SqlConnection con;
SqlDataAdapter da;
DataSet dsl;

public Form1()
{
InitializeComponent();
con = new SqlConnection(@"Data Source=TALY-PC;Initial Catalog=Katalogi;Integrated Security=True;Pooling=False");
da = new SqlDataAdapter("SELECT * FROM tblArtikujt", con);
dsl = new DataSet();
}
}

我会让你research the using block yourself

关于c# - 错误 - 字段初始值设定项无法引用非静态字段、方法或属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13770287/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com