多くの場合、データベース接続の初期化プロセスを Page_Load に任せることに慣れていますが、実際、この方法には利点と欠点があり、一方的な問題が発生した場合には非常に実用的です。この状況ではこれはあまり役に立ちません。例:
/// 例:
<script language="C#" runat="server">
SqlConnection mySqlCon;
protected void Page_Load(Object Src,EventArgs E)
{
mySqlCon=new SqlConnection("server=localhost;uid=sa;pwd=sa;database=pubs"); //初期化処理
if (!IsPostBack)
バインドグリッド();
}
public void AddPublisher(オブジェクト送信者, EventArgs E)
{
String myinsertCmd = "発行者 (pub_id、pub_name、市、州、国) の値 (@pubid,@pubname,@city,@state,@country) に挿入します";
SqlCommand mySqlCom = new SqlCommand(myinsertCmd, mySqlCon); //初期化コマンド呼び出し
//マッチングを実現する
mySqlCom.Parameters.Add(new SqlParameter("@pubid", SqlDbType.Char, 4));
mySqlCom.Parameters["@pubid"].Value = Pub_Id.Text;
mySqlCom.Parameters.Add(new SqlParameter("@pubname", SqlDbType.VarChar, 40));
mySqlCom.Parameters["@pubname"].Value = Pub_Name.Text;
mySqlCom.Parameters.Add(new SqlParameter("@city", SqlDbType.VarChar, 20));
mySqlCom.Parameters["@city"].Value = City.Text;
mySqlCom.Parameters.Add(new SqlParameter("@state", SqlDbType.Char, 2));
mySqlCom.Parameters["@state"].Value = State.Text;
mySqlCom.Parameters.Add(new SqlParameter("@country",SqlDbType.VarChar, 30));
mySqlCom.Parameters["@country"].Value = Country.Text;
//DBを開く
mySqlCom.Connection.Open();
mySqlCom.ExecuteNonQuery();
Message.InnerHtml = "<b>レコードが追加されました</b><br/>";
mySqlCom.Connection.Close();
Pub_Id.Text = "";
Pub_Name.Text = "";
City.Text= "";
State.Text = "";
Country.Text = "";
バインドグリッド();
}
//サブ関数呼び出し
public void BindGrid()
{
SqlDataAdapter mySqlCom = new SqlDataAdapter("select * from pub_id like '99%'", mySqlCon);
DataSet myds = new DataSet();
mySqlCom.Fill(myds, "パブリッシャー");
dgMyGrid.DataSource = myds.Tables["publishers"].DefaultView;
}
</script>
<h2>新しいパブリッシャーを追加します:</h2>
<br/>
発行者 ID は 99 で始まり、4 桁の数字を含む必要があります<br/>
発行者 ID:
<asp:textbox id="Pub_Id" runat="server" />名前:
<asp:textbox id="Pub_Name" runat="server" />
都市:
<asp:textbox id="都市" runat="サーバー" />
<br/>
都道府県:
<asp:textbox id="状態" runat="サーバー" />
国:
<asp:textbox id="国" runat="サーバー" />
<br/>
<br/>
<asp:button Text="Submit" OnClick="AddPublisher" runat="server" ID="Button1" /><br/>
<span id="メッセージ" runat="サーバー" />
<br/>
<asp:DataGrid id="dgMyGrid" runat="server" />
この例は一見問題ないように見えますが、デバッグ中にエラーは報告されません。ただし、生成されたページにデータを追加すると、エラーが報告されます。属性が一致しないと言って送信します。原因は何ですか?実際、これはページの読み込み時の初期化プロセスが原因で発生しますが、ここには私が理解できなかった問題があります。つまり、DB インスタンスはページの初期化プロセス中に初期化されているため、アプリケーションを直接生成することも可能ですが、そうではないようです。それを実現するには、初期化プロセスを特定の関数に組み込む必要があります。以下を参照してください:
<<スクリプト言語="C#" runat="サーバー">
protected void Page_Load(Object Src,EventArgs E)
{
//IF ステートメントはページの読み込み中に直接使用されますが、実際には何も追加されません。
if (!IsPostBack)
バインドグリッド();
}
public void AddPublisher(オブジェクト送信者, EventArgs E)
{
string strprovider="server=localhost;uid=sa;pwd=sa;database=pubs"; //初期化プロセスを構築する
SqlConnection mySqlCon=new SqlConnection(strprovider);
string myinsertCmd ="パブリッシャー ( pub_id、pub_name、city、state、country ) の値 (@pubid,@pubname,@city,@state,@country) に挿入します";
SqlCommand mySqlCom = new SqlCommand(myinsertCmd,mySqlCon); //初期化処理の実装
mySqlCom.Parameters.Add(new SqlParameter("@pubid", SqlDbType.Char, 4));
mySqlCom.Parameters["@pubid"].Value = Pub_Id.Text;
mySqlCom.Parameters.Add(new SqlParameter("@pubname", SqlDbType.VarChar, 40));
mySqlCom.Parameters["@pubname"].Value = Pub_Name.Text;
mySqlCom.Parameters.Add(new SqlParameter("@city", SqlDbType.VarChar, 20));
mySqlCom.Parameters["@city"].Value = City.Text;
mySqlCom.Parameters.Add(new SqlParameter("@state", SqlDbType.Char, 2));
mySqlCom.Parameters["@state"].Value = State.Text;
mySqlCom.Parameters.Add(new SqlParameter("@country",SqlDbType.VarChar, 30));
mySqlCom.Parameters["@country"].Value = Country.Text;
mySqlCom.Connection.Open();
mySqlCom.ExecuteNonQuery();
Message.InnerHtml = "<b>レコードが追加されました</b><br>";
mySqlCom.Connection.Close();
Pub_Id.Text = "";
Pub_Name.Text = "";
City.Text= "";
State.Text = "";
Country.Text = "";
バインドグリッド();
}
public void BindGrid() サブ関数を呼び出すときは、DB 接続も初期化する必要があります。
{
文字列 strprovider="server=dev;uid=sa;pwd=pauperboyboy;database=pubs";
SqlConnection mySqlCon=new SqlConnection(strprovider);
SqlDataAdapter mySqlCom = new SqlDataAdapter("select * from pub_id like '99%'",mySqlCon);
DataSet myds = new DataSet();
mySqlCom.Fill(myds, "パブリッシャー");
dgMyGrid.DataSource = myds.Tables["publishers"].DefaultView;
dgMyGrid.DataBind();
}
</script>
<h2>新しいパブリッシャーを追加します:</h2>
<br>
発行者 ID は 99 で始まり、4 桁の数字が含まれている必要があります<br>
発行者 ID:
<asp:textbox id="Pub_Id" runat="server" />名前:
<asp:textbox id="Pub_Name" runat="server" />
都市:
<asp:textbox id="都市" runat="サーバー" />
<br>
都道府県:
<asp:textbox id="状態" runat="サーバー" />
国:
<asp:textbox id="国" runat="サーバー" />
<br>
<br>
<asp:button Text="Submit" OnClick="AddPublisher" runat="server" ID="Button1" /><br>
<span id="メッセージ" runat="サーバー" />
<br>
<asp:DataGrid id="dgMyGrid" runat="サーバー" />
</form>>
このような修正を経て、本当の意味でのデータ増加が実現できます!ただし、ページをロードしたときにデータを削除して更新してみましたが、問題はありませんでした。理由がわかる人は教えてください。ありがとう:)