2014年用 ADO.NET 连接数据库.ppt
文本预览下载声明
小结 如果 try 中没有出现异常,显示哪几个消息框? try { // … 可能出现异常的代码 MessageBox.Show(try块); } catch (Exception e) { MessageBox.Show(catch块); } finally { MessageBox.Show(finally块); } 显示 显示 不显示 为什么使用 Command 应用程序 打开数据库 处理数据 …… 数据源 Connection 怎样处理数据 执行命令并从数据源中返回结果 操作数据库示例 查询 MySchool 数据库 Student 表中记录的数目 演示示例3:查询Student表记录条数 Command 的主要成员 属性 说明 Connection Command对象使用的数据库连接 CommandText 执行的SQL语句 方法 说明 ExecuteNonQuery 执行不返回行的语句,如UPDATE等 ExecuteReader 返回DataReader对象 ExecuteScalar 返回单个值,如执行COUNT(*) 使用 Command 步骤 使用Command步骤: 1、创建数据库连接 2、定义 SQL 语句 3、创建 Command 对象 4、执行命令 SqlConnection connection = new SqlConnection(connString); string sql = SELECT COUNT(*) FROM Student; connection.Open();// 打开数据库连接 SqlCommand command = new SqlCommand(sql, connection); int num = (int)command.ExecuteScalar(); 示例 3 关键代码: 执行命令前,必须打开数据库连接! 要进行类型转换! 综合示例 完成系统登录功能 1、验证管理员的用户名和密码是否存在 2、验证通过,显示管理员主窗体 处理登录按钮的 Click 事件 定义一个 ValidateUser() 方法 需要 Connection 和 Command 对象 分两步实现验证: 1、建立数据库连接 2、验证用户是否存在 用户验证方法框架 ValidateUser() 方法框架 1、验证的结果:通过,不通过 返回值为 bool 型 2、方法需要: 用户名,密码,登录类型 值方式传参 3、不通过的原因: 用户名或密码不存在、其他原因 引用方式传参 public bool ValidateUser(string loginType, string loginId, string loginPwd, ref string message) { } 演示示例4:增加方法的定义和调用 用户验证方法具体实现 第一步:建立数据库连接 增加 DBHelper 类 第二步:查询用户是否存在 SELECT COUNT(*) ExecuteScalar() 方法查询 演示示例5:用户验证方法具体实现 ValidateUser() 方法具体实现 小结 // 查询 Student 表使用的 SQL 语句 string sql = string.Format( SELECT COUNT(*) FROM Student WHERE LogInId={0} AND LogInPwd={1},txtLogInId, txtLogInPwd); // 使用的 Command 对象 SqlCommand command = new SqlCommand(sql, DBHelper.connection); DBHelper.connection.Open(); // 执行查询,返回找到的个数 count = (int)command.ExecuteScalar(); 在示例5中增加验证学员用户的代码 总结 Connection 对象的什么方法用来打开和关闭数据库连接? ExecuteScalar()方法返回什么? 谢谢聆听! * * * * 介绍整个MySchool数据库表的结构,其中用红框框起来的是理论课贯穿案例使用到的数据表。 * 只进:是指对于查询处的结果,只能前进,不能后退。例如:前进到了第3条结果,就不能再返回到第一条或第二条结果。 只读:是指只能读取数据,不能修改数据。 * 介绍.NET数据提供程序的4个核心对象。 解释ADO.NET操作数据库的几条线路,让学
显示全部