ADO.NET 【实体类】【数据访问类】
三层架构(3-tier architecture)
界面层(User Interface layer) 主要对用户的请求接受,以及数据的返回,为客户端提供应用程序的访问。
业务逻辑层(Business Logic Layer)主要是针对具体的问题的操作,也可以理解成对数据层的操作
数据访问层(Data access layer)主要是对非原始数据(数据库或者文本文件等存放数据的形式)的操作层
数据访问层包括 实体类 ,数据访问类
1、开发人员可以只关注整个结构中的其中某一层;
2、可以很容易的用新的实现来替换原有层次的实现;
3、可以降低层与层之间的依赖;
4、有利于标准化;
5、利于各层逻辑的复用。
6、结构更加的明确
7、在后期维护的时候,极大地降低了维护成本和维护时间
1、降低了系统的性能。这是不言而喻的。如果不采用分层式结构,很多业务可以直接造访数据库,以此获取相应的数据,如今却必须通过中间层来完成。
2、有时会导致级联的修改。这种修改尤其体现在自上而下的方向。如果在表示层中需要增加一个功能,为保证其设计符合分层式结构,可能需要在相应的业务逻辑层和数据访问层中都增加相应的代码。
3、增加了开发成本。
*** 约定 在项目下建文件夹 App_Code 要创建的实体类文件,操作类文件都放在改文件夹下。
实体类文件名=表明,操作类文件名=表名+Data
1、实体类
-- 数据库映射出来的结构对象,最简单的封装。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; namespace ConsoleApplication2.App_Code
{
public class Users
{
private int _Ids; public int Ids
{
get { return _Ids; }
set { _Ids = value; }
}
private string _UserName; public string UserName
{
get { return _UserName; }
set { _UserName = value; }
}
private string _PassWord; public string PassWord
{
get { return _PassWord; }
set { _PassWord = value; }
}
private string _NickName; public string NickName
{
get { return _NickName; }
set { _NickName = value; }
}
private bool _Sex; public bool Sex
{
get { return _Sex; }
set { _Sex = value; }
}
private DateTime _Birthday; public DateTime Birthday
{
get { return _Birthday; }
set { _Birthday = value; }
}
private string _Nation; public string Nation
{
get { return _Nation; }
set { _Nation = value; }
} }
}
对表 users 建立查询,添加操作类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SqlClient; namespace ConsoleApplication2.App_Code
{
public class UsersData
{
SqlConnection conn = null; //“公海” 提升 conn cmd 的作用域
SqlCommand cmd = null; public UsersData() //构造函数,放置每个方法都要使用,每次实例化都要运行
{
string sql = "server=.;database=Data0216;user=sa;pwd=123"; conn = new SqlConnection(sql);
cmd = conn.CreateCommand();
} //查询所有方法 public List<Users> SelectAll() //有返回值 List<Users> 返回一个集合,
{
List<Users> list = new List<Users>(); //实例化一个 集合 cmd.CommandText = "select *from Users"; //查询语句 conn.Open(); SqlDataReader dr = cmd.ExecuteReader(); while (dr.Read()) //在这里没有进行有无 行 的判断,直接读取记录
{ Users u = new Users(); //实例化一个 users 对象,前提是已经建立 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.Nation = dr["Nation"].ToString(); list.Add(u);
}
conn.Close(); return list; //返回 list
} //添加记录方法
public void Insert(Users u) //需要输入,输入一个 users 类型的变量
{
cmd.CommandText = "insert into Users values(@username,@password,@nickname,@sex,@birthday,@nation)"; cmd.Parameters.Clear();
cmd.Parameters.AddWithValue("@username", u.UserName);
cmd.Parameters.AddWithValue("@password", u.PassWord);
cmd.Parameters.AddWithValue("@nickname", u.NickName);
cmd.Parameters.AddWithValue("@sex", u.Sex);
cmd.Parameters.AddWithValue("@birthday", u.Birthday);
cmd.Parameters.AddWithValue("@nation", u.Nation); conn.Open();
cmd.ExecuteNonQuery();
conn.Close();
} }
}
练习
对 Student表,重新排序 。如当 S002 删除后剩下的重新排序
S001 S001
S003 S002
S004 S003
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data.SqlClient; namespace ConsoleApplication2
{
class Program
{
static void Main(string[] args)
{
int max = ; string sql = "server=.;database=Data0216;user=sa;pwd=123";
SqlConnection conn = new SqlConnection(sql);
SqlCommand cmd = conn.CreateCommand(); //查询总数
cmd.CommandText = "select COUNT(*) from Students"; conn.Open(); SqlDataReader dr = cmd.ExecuteReader(); dr.Read();
// max 共有多少条记录
max = Convert.ToInt32(dr[]); conn.Close(); conn.Open(); //将编号从1到 max 变为s001~s00max
for (int i = ; i < max; i++)
{
string newcode = "S" + (i + ).ToString(""); cmd.CommandText = "update Students set Scode='" + newcode + "' where ids = (select top 1 ids from Students where Ids not in(select top " + i + " ids from Students)) "; cmd.ExecuteNonQuery();
}
conn.Close(); Console.WriteLine("成功了!"); Console.ReadLine();
}
}
}
select top 1 * from student ;
—— 查询全部取第一行
select top 2 * from student ;
—— 查询全部取前两行
select top 1 * from student where ids not in ( select top 1 ids from student )
—— 查询第二行 括号内1变为 2 取第三行
方法2、使用实体类、操作类
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; namespace ConsoleApplication2.App_Code
{
public class Students
{
private int _Ids; public int Ids
{
get { return _Ids; }
set { _Ids = value; }
}
private string _Scode; public string Scode
{
get { return _Scode; }
set { _Scode = value; }
}
private string _Sname; public string Sname
{
get { return _Sname; }
set { _Sname = value; }
} }
}
student 实体类
using System;
using System.Collections.Generic;
using System.Data.SqlClient;
using System.Linq;
using System.Text; namespace ConsoleApplication2.App_Code
{
public class StudentsData
{
SqlConnection conn = null;
SqlCommand cmd = null; public StudentsData()
{
conn = new SqlConnection("server=.;database=Data0216;user=sa;pwd=123");
cmd = conn.CreateCommand();
} public void ResetNumber()//没有返回值的操作类
{
List<Students> slist = new List<Students>();//返回一个泛型集合 cmd.CommandText = "select *from Students"; conn.Open(); SqlDataReader dr = cmd.ExecuteReader(); while (dr.Read())
{
Students s = new Students();//实例化一个 Student 对象 s.Ids = Convert.ToInt32(dr["Ids"]);
s.Scode = dr["Scode"].ToString();
s.Sname = dr["Sname"].ToString(); slist.Add(s);//接受
}
conn.Close(); int count = ; //遍历,更改所有的编号
foreach (Students sss in slist)
{
sss.Scode = "S" + count.ToString("");
count++;
} conn.Open(); //将改好的编号添加进去
foreach (Students ss in slist)
{
cmd.CommandText = "Update Students set Scode=@a where Ids = @b";
cmd.Parameters.Clear();
cmd.Parameters.AddWithValue("@a", ss.Scode);
cmd.Parameters.AddWithValue("@b", ss.Ids);
cmd.ExecuteNonQuery();
}
conn.Close(); } }
}
student 操作类
using System.Text;
using ConsoleApplication2.App_Code; namespace ConsoleApplication2
{
class Program
{
static void Main(string[] args)
{ StudentsData st = new StudentsData();
st.ResetNumber(); // 可简化写为 new StudentsData().ResetNumber(); Console.ReadKey();
}
}
}
min 接口操作
ADO.NET 【实体类】【数据访问类】的更多相关文章
- ado.net 实体类_数据访问类
实体类: using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace ...
- ADO.net 实体类 、数据访问类
程序分三层:界面层.业务逻辑层.数据访问层 比较规范的写程序方法,要把业务逻辑层和数据访问层分开,此时需要创建实体类和数据访问类 实体类: 例 using System; using System.C ...
- ADO,NET 实体类 和 数据访问类
啥也不说,看代码. --SQl中 --建立ren的数据库,插入一条信息 create database ren go use ren go create table xinxi ( code ) pr ...
- ADO.NET(完整修改和查询、实体类,数据访问类)
一.完整修改和查询 在编写c#语句时需考虑到用户体验,例如在编写修改语句时,需要考虑到输入的内容在数据库中是否能够找到. 中间变量运用. 1.先查 2.执行操作 完整修改语句: bool has = ...
- 【2017-04-20】Ado.Net与面向对象结合架构中的数据访问层(实体类,数据访问类)
开发项目三层架构:界面层.业务逻辑层.数据访问层 今天学习一下数据访问层,分为实体类和数据访问类 所有的类放在App_Code这个文件夹下边.养成一个好的习惯. 一.实体类 数据库中的表映射为一个类, ...
- 9_13学习完整修改和查询&&实体类,数据访问类
完整修改和查询:中间变量运用. 1.先查 2.执行操作 ---------------------------------------------------- namespace ADO.NET_小 ...
- ADO.NET(一) 空间 ADO.NET结构 命名空间(车延禄) System.Data—— 所有的一般数据访问类 S(转载)
ADO.NET(一) 空间 ADO.NET结构 命名空间(车延禄)System.Data—— 所有的一般数据访问类System.Data.Common—— 各个数据提供程序共享(或重写)的类Sys ...
- ADO.NET 数据访问类查询、属性扩展
今天,我首先在之前所做的人员管理系统的基础上,利用数据访问类进行了所有人员信息的查询. 主程序代码: List<Users> Ulist = new UsersData().Select( ...
- 【2017-04-20】Sql字符串注入式攻击与防御,实体类,数据访问类
字符串攻击 所谓sql字符串注入式攻击就是在用户输入界面输入通过精心编制的含有某种指令的字符串,来改变C#中连接数据库要执行的sql语句,从而对数据库进行攻击性操作 在用户输入界面输入 a');up ...
随机推荐
- python安装mysql-python依赖包
# 背景 新公司,对换工作了!接口自动化使用的是python的behave框架,因此需要折腾python了,而公司配的笔记本是windows的,因此要在windows下折腾python了 # 步骤 项 ...
- JS学习笔记1_基础与常识
1.六种数据类型 5种基础的:Undefined,Null,Boolean,Number,String(其中Undefined派生自Null) 1种复杂的:Object(本质是一组无序键值对) 2.字 ...
- VS2015+MySql+EF6采坑经验总结
背景:VS2015+MySql+EF6(DB First) 采坑顺序:按照以前的记忆,操作依次如下: 1,安装 MySQL Connector/NET(不用想,装最新的,8.0.12) 2.安装 My ...
- 【转】OAuth的改变
原文地址:http://huoding.com/2011/11/08/126 去年我写过一篇<OAuth那些事儿>,对OAuth做了一些简单扼要的介绍,今天我打算写一些细节,以阐明OAut ...
- 企业项目开发--cookie(3)
此文已由作者赵计刚授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 2.2.3.AdminController 1 package com.xxx.web.admin; ...
- 简单的C# Socket通信实例
一.套接字(socket)概念 套接字(socket)是通信的基石,是支持TCP/IP协议的网络通信的基本操作单元.它是网络通信过程中端点的抽象表示,包含进行网络通信必须的五种信息:连接使用的协议,本 ...
- [ZJOI2010]基站选址(线段树优化dp)
坑待填. \(Code\ Below:\) #include <bits/stdc++.h> #define lson (rt<<1) #define rson (rt< ...
- 跟着刚哥学习Spring框架--AOP(五)
AOP AOP(Aspect Oriented Programming),即面向切面编程,可以说是OOP(Object Oriented Programming,面向对象编程)的补充和完善.OOP引入 ...
- Shell - 简明Shell入门07 - 数组(Array)
示例脚本及注释 #!/bin/bash test0=() # 定义数组 test1=(a b c d e f) # 定义数组 test2=( # 定义数组 'A?' "BB!" C ...
- swiper4-vue 不使用loop,由最后一张跳到第一张
<template> <div class="swiper-box"> <div class="swiper-container" ...