C# ADO.NET与面向对象
软件开发的三层:界面层,业务逻辑层,数据访问层;
数据访问层:项目添加App_Code文件夹;
实体类:根据数据库表结构,类名和数据库表名一致;
每个成员变量要与数据库表的列相对应,对象正好可以列为一行数据,封装起来;
一个实体类做一个类;
访问权限是public的
数据访问类:起名UsersData;
访问权限是public的
实体类和数据访问类统称为数据访问层,每个表对应一个数据访问层;
新建一个连接字符串的静态的类:
访问权限是public的,必须有一个静态的成员变量,然后封装;
连接字符串:成员变量 = "server =.; Database =Data0908; user =sa; pwd =123;";
在数据访问操作的方法:在数据访问类的构造函数内,可以直接用连接字符串的类名点出来;
在构造函数内可以直接连接数据库:
SqlConnection conn = new SqlConnection();
SqlCommend comm = conn.CreateCommand();
*****写法:
由于构造函数的约束性,可以提升数据库连接类和数据库操作类的作用域:
private SqlConnection conn;
private SqlCommend comm;
public UsersData
{
conn = new SqlConnection(连接字符串的类名.连接字符串的成员变量);
comm = conn.CreateCommand;
}
//返回表中的所有数据
public List <Users> selectAll()
{
List <Users> us = new List<Users>(); //新建一个泛型集合
comm.CommandText = "select * from Users";
conn.Open();
SqlDataReader dr = comm.ExeuteReader();
return us;
}
while(dr.Read()) //如果dr.Read是true进循环;
{
Users u = new Users;
u.Ids = Convert.ToInt32(dr[Ids]);
u.UserName = dr[UserName].ToString();
u.password = dr[password].ToString();
u.NickName = dr[NickName].ToString();
u.Sex = Convert.ToBoolean(dr[Sex]);
u.Birthday = Convert.ToDateTime(dr[Birthday]);
u.NationCold = dr[NationCold].ToString();
us.Add(u);
}
conn.Close();
return us;
}
foreach(Users u in ulist)
{
Console.WriteLine(u.Ids+" | "+u.password);
}
添加:
public bool UsersTianJia(users u)
{
bool result = false; //默认结果false;
cmd.CommandText = "insert into Users values(@a,@b,@c,@d,@e,@f)";
cmd.Parameters.Clear();
cmd.Parameters.AddWithValue("@a", u.UserName);
cmd.Parameters.AddWithValue("@b", u.PassWord);
cmd.Parameters.AddWithValue("@c", u.NickName);
cmd.Parameters.AddWithValue("@d", u.Sex);
cmd.Parameters.AddWithValue("@e", u.Birthday);
cmd.Parameters.AddWithValue("@f", u.NationCode);
conn.Open();
int a = comm.ExcuteNonQuery();
conn.Close();
if(a>0)
result = true;
return result;
}
Users user = new Users();
Console.WriteLine("请输入用户名");
user.UserName = Console.ReadLine();
C# ADO.NET与面向对象的更多相关文章
- 【2017-04-20】Ado.Net与面向对象结合架构中的数据访问层(实体类,数据访问类)
开发项目三层架构:界面层.业务逻辑层.数据访问层 今天学习一下数据访问层,分为实体类和数据访问类 所有的类放在App_Code这个文件夹下边.养成一个好的习惯. 一.实体类 数据库中的表映射为一个类, ...
- C# ADO.NET 面向对象
ADO.NET跟面向对象的结合 把面向对象跟数据库连接用 在项目里面创建一个新的文件夹 名字为App_Code 在这个App_Code里面创建几个类 主要为拆分问题,标上序号,先干什么在干什么 实 ...
- ADO.NET(查询、属性扩展)
一.ADO.NET 融合面向对象的查询语句 1.只查询一条数据 //数据访问中的select方法 public stu select(string xuehao) { stu s = null; cm ...
- C# ADO.NET面向对象想法
我认为的面向对象就是把各种问题拆分开来 逐一解决, 我想的是先是数据库,到底有什么, 然后新建一个类,类里面先是private的私有的,但是可以有无数个可以连接private的pubilc的属性 可 ...
- ado.net 面向对象
面向对象:就是一个大的转换器,建立起一条通道通往数据库然后通过通道将所需(方法)数据从转换器往返于外部界面端 1 首先在项目里创建文件夹: 右击项目———添加个文件夹App_Cod 2 ...
- .NET基础拾遗(2)面向对象的实现和异常的处理基础
Index : (1)类型语法.内存管理和垃圾回收基础 (2)面向对象的实现和异常的处理基础 (3)字符串.集合与流 (4)委托.事件.反射与特性 (5)多线程开发基础 (6)ADO.NET与数据库开 ...
- .NET基础拾遗(6)ADO.NET与数据库开发基础
Index : (1)类型语法.内存管理和垃圾回收基础 (2)面向对象的实现和异常的处理 (3)字符串.集合与流 (4)委托.事件.反射与特性 (5)多线程开发基础 (6)ADO.NET与数据库开发基 ...
- ADO.NET Entity Framework 在哪些场景下使用?
在知乎回答了下,顺手转回来. Enity Framework已经是.NET下最主要的ORM了.而ORM从一个Mapping的概念开始,到现在已经得到了一定的升华,特别是EF等对ORM框架面向对象能力的 ...
- Entity Framework 与 面向对象
说要分享,我了个*,写了一半放草稿箱了两个星期都快发霉了,趁着周末写完发出来吧. 文章分为五部分: 基础.类讲述的是用到的一些EF与面向对象的基础: 业务是讲怎么划分设计业务: 设计模式和工作模式讲述 ...
随机推荐
- .net core实践系列之短信服务-Sikiro.SMS.Bus服务的实现
前言 前两篇<.net core实践系列之短信服务-Sikiro.SMS.Api服务的实现>.<.net core实践系列之短信服务-Api的SDK的实现与测试>分别讲解了AP ...
- RabbitMQ 延时消息设计
问题背景 所谓"延时消息"是指当消息被发送以后,并不想让消费者立即拿到消息,而是等待指定时间后,消费者才拿到这个消息进行消费. 场景一:客户A在十二点下了一个订单,我想半个小时后来 ...
- EF_DataFrist遇到的问题
正在 Code First 模式下将此上下文与从 EDMX 文件生成的用于 Database First 或 Model First 开发的代码一起使用.这将无法正常工作.若要解决此问题,请不要删除引 ...
- 针对Nginx日志的相关运维操作记录
在分析服务器运行情况和业务数据时,nginx日志是非常可靠的数据来源,而掌握常用的nginx日志分析命令的应用技巧则有着事半功倍的作用,可以快速进行定位和统计. 1)Nginx日志的标准格式(可参考: ...
- PHP中报500错误时如何查看错误信息
在执行代码中加入下面两行代码即可 ini_set("display_errors","On"); error_reporting(E_ALL);
- Rop框架学习笔记
1. 提供了开发服务平台的解决方案:比如应用认证.会话管理.安全控制.错误模型.版本管理.超时限制 2. 启动:RopServlet截获http请求 配置: <servlet> < ...
- 个人作业 Last
对M1/M2阶段的总结 M1阶段的总结反思见我以前的博客,我以前曾经写过.现附上链接.http://www.cnblogs.com/jirufeng/p/4990245.html M2阶段主要是对我们 ...
- hash函数补分博客
题目要求: 利用除留余数法为下列关键字集合的存储设计hash函数,并画出分别用开放寻址法和拉链法解决冲突得到的空间存储状态(散列因子取0.75) 关键字集合:85,75,57,60,65,(你的8位学 ...
- 计算机终端安装成功的包 pycharm不能更新
最近在学习python的时候遇到一个麻烦事 要用到pymssql包 在CMD下已经安装成功 但是在pycharm中运行的时候出现 没有这个包 以往的方法是在设置界面 通过+号安装需要的包 但 ...
- 开发中CollectionUtils处理集合
1.org.apache.commons.collections.CollectionUtils; 使用这个工具类,帮我们处理一些集合的操作,非常方便 //取并集public void testUni ...