ADO.NET:
是微软最强大的数据库访问技术,应用程序可以通过ADO.NET可以非常方便的访问并处理存储在各种数据库的中的数据。ADO.NET集成于.NetFrameWork之中,可用于任何支持.Net的程序设计语言。
命名空间:System.Data.SqlClient;
1. 创建一个数据库:
-
VS中选择:视图——服务器资源管理器
右击“数据连接”,选择“创建新的SqlServer数据库”,然后选择服务器名,并在下面创建一个名称为“MySchool”的数据库。
-
新建数据表:
拆开刚刚新建的数据库MySchool,然后在下拉中右击“表”,选择”添加新表”,然后分别键入UserID,UserName,PassWord作为列名。
然后保存数据表名称为“User”。 -
添加表数据:右击User数据表,选择“显示表数据”。然后添加3个用户。
2. 使用SqlConnection对象连接数据库,并执行【增、删、改、查】
连接方式有两种:Windows & SqlServer
Windows连接字符串: “server=服务器名称;database=数据库名称;Trusted_Connection=SSPI”;
SqlServer连接字符串: “server=服务器名称;uid=登录名称;pwd=登录密码;database=数据库名称”;
- 在此之前我们需要将连接字符串添加到配置xml文件中,防止软件首次打开时连接不上数据库。
- 【修改数据】 打开数据库并执行修改表内容的操作:
public static string connStr = ConfigurationManager.ConnectionStrings["connStr"].ToString(); //从配置文件中读取连接字符串
string upDateStr ="UPDATE User SET PassWord='abc' WHERE UserName=Admin"; //修改User表中Admin用户的密码为“abc”
try
{
//SqlConnection对象在每一次执行命令后销毁
using (SqlConnection con = new SqlConnection(connStr))
{
con.Open();
SqlCommand cmd = new SqlCommand(upDateStr, con);
int result = cmd.ExecuteNonQuery(); //这里返回受影响的行数,用于验证执行是否成功
}
}
catch(Exception ex)
{
throw ex;
}
- 【新增数据】打开数据库并执行添加表内容的操作:
public static string connStr = ConfigurationManager.ConnectionStrings["connStr"].ToString();
string addDateStr =string.Format("INSERT INTO User(UserID,UserName,PassWord) VALUES('{0}','{1}','{2}')",4,"Teacher","321"); //添加一个用户名为Teacher的新用户,密码321。
try
{
using (SqlConnection con = new SqlConnection(connStr))
{
con.Open();
SqlCommand cmd = new SqlCommand(addDateStr , con);
int result = cmd.ExecuteNonQuery(); //这里返回受影响的行数,用于验证执行是否成功。
if(result>0) MessageBox.Show("添加成功!");
else MessageBox.Show("添加失败!");
}
}
catch(Exception ex)
{
throw ex;
}
- 【查询数据】打开数据库并查询表内容的操作:
public static string connStr = ConfigurationManager.ConnectionStrings["connStr"].ToString();
string queryDateStr =string.Format("SELECT *FROM User WHERE UserID='{0}'", 1); //查询User表中用户ID为1的数据源
try
{
//SqlConnection对象在每一次执行命令后销毁
using (SqlConnection con = new SqlConnection(connStr))
{
con.Open();
SqlCommand cmd = new SqlCommand(queryDateStr , con);
SqlDataReader reader= cmd.ExecuteReader(); //这里返回一个reader对象
if(reader.Read())
{
string userName=reader.GetString(1);
//这里GetString(index)中: 0=UserID,1=UserName,2=PassWord
}
reader.Close();
}
}
catch(Exception ex)
{
throw ex;
}
- 【删除数据】打开数据库并删除表内容的操作:
public static string connStr = ConfigurationManager.ConnectionStrings["connStr"].ToString();
string delDateStr =string.Format("DELETE FROM User WHERE UserName='{0}'", "Teacher"); //删除用户名为Teacher的数据
try
{
//SqlConnection对象在每一次执行命令后销毁
using (SqlConnection con = new SqlConnection(connStr))
{
con.Open();
SqlCommand cmd = new SqlCommand(delDateStr, con);
int result = cmd.ExecuteNonQuery();
if(result>0) MessageBox.Show("删除成功!");
else MessageBox.Show("删除失败!");
}
}
catch(Exception ex)
{
throw ex;
}
3. 使用DataSet和DataAdapter显示数据集
SqlDataAdapter adapter = new SqlDataAdapter();
DataSet dataSet = new DataSet();
string sql = "SELECT UserID as 用户编号,UserName as 用户名,PassWord as 密码 FROM User";
SqlConnection con = new SqlConnection(conStr);
con.Open();
SqlCommand com = new SqlCommand(sql, con);
adapter.SelectCommand = com;
SqlCommandBuilder builder = new SqlCommandBuilder(adapter);
adapter.Fill(dataSet, "User");
object table = dataSet.Tables["User"];
foreach (DataRow row in dataSet.Tables["User"].Rows)
{
row[0]; //表示当前遍历的行的第0列。
}
con.Close();
【如有错误,欢迎指正】