I have build a DataGridView and read a sql table fine. But the data could not be update back to SQL Server by SqlDataAdapter.Update()
, I get error:
connectionstring property has not been initialized
This is my code:
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.SqlClient;
namespace test_2
{
public partial class Form1 : Form
{
SqlDataAdapter sda;
DataSet ds;
BindingSource bind1 = new BindingSource();
SqlCommandBuilder scb;
public Form1()
{
InitializeComponent();
}
private void Form1_Load(object sender, EventArgs e)
{
using (SqlConnection cn = new SqlConnection(Properties.Settings.Default.ConnString))
{
ShowData();
SqlCommandBuilder commandBuilder = new SqlCommandBuilder(sda);
bind1.DataSource = ds;
}
}
private void ShowData()
{
using (SqlConnection cn = new SqlConnection(Properties.Settings.Default.ConnString))
{
sda = new SqlDataAdapter("select key_seq, po_no, ref_no from mpo_master", cn);
ds = new DataSet();
sda.Fill(ds, "MPO");
dataGridView1.DataSource = ds.Tables["MPO"];
}
}
private void button1_Click(object sender, EventArgs e)
{
try
{
using (SqlConnection cn = new SqlConnection(Properties.Settings.Default.ConnString))
{
scb = new SqlCommandBuilder(sda);
sda.Update(ds, "MPO");
MessageBox.Show("Information Updated", "Update", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
}
}
}
this is the config file:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<sectionGroup name="applicationSettings" type="System.Configuration.ApplicationSettingsGroup, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" >
<section name="VGB_Purchase.Properties.Settings" type="System.Configuration.ClientSettingsSection, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
</sectionGroup>
</configSections>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5.2" />
</startup>
<applicationSettings>
<VGB_Purchase.Properties.Settings>
<setting name="connString" serializeAs="String">
<value>Data Source=vgb-angus;Initial Catalog=VGB_Purchase;Persist Security Info=True;User ID=sa;Password=jessie</value>
</setting>
</VGB_Purchase.Properties.Settings>
</applicationSettings>