ADO,NET 实体类 和 数据访问类

时间:2021-07-25 13:17:01

啥也不说,看代码。

--SQl中
--建立ren的数据库,插入一条信息
create database ren
go
use ren
go
create table xinxi
(
code nvarchar(20) primary key,--编号
name nvarchar(20)--名字
)
insert into xinxi values('','zhangsan')

1、建立实体类:

实体类:封装
封装一个类,类名与数据库表名一致
成员变量名与列名一致,多一个下划线
成员变量封装完的属性,就会与数据表中的列名一致

每一行数据都可以存成一个对象,操作这个对象,就相当于对某一行数据进行整体操作

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks; namespace ConsoleApplication71.App_Code
{
public class xinxi
{
private string _code;
public string code
{
get { return _code; }
set { _code = value; }
}
private string _name;
public string name
{
get { return _name; }
set { _name = value; }
}
}
}

2、建立数据访问类:

就是将对数据库的一些操作,单独写到一个类中,封成一些方法,等待调用。

结构看起来会非常清晰。

就像html中的CSS样式表和javascript的关系

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Data.SqlClient; namespace ConsoleApplication71.App_Code
{ public class xinxidata
{
SqlConnection cnn = null;
SqlCommand cmd = null; public xinxidata()
{
cnn = new SqlConnection("server=.;database=ren;user=sa;pwd=123");
cmd = cnn.CreateCommand();
} /// <summary>
/// 增加
/// </summary>
/// <param name="x">信息对象</param>
public void insert(xinxi x)
{ cmd.CommandText = "insert into xinxi values(@a,@b)";
cmd.Parameters.Clear();
cmd.Parameters.Add("@a",x.code);
cmd.Parameters.Add("@b",x.name);
cnn.Open();
cmd.ExecuteNonQuery();
cnn.Close();
} //查询
public xinxi chaxun(string code)
{
xinxi xin = null;
cmd.CommandText = "select * from xinxi where code=@code";
cmd.Parameters.Clear();
cmd.Parameters.Add("@code",code);
cnn.Open();
SqlDataReader ss = cmd.ExecuteReader();
if (ss.HasRows)//判断有没有
{
xin = new xinxi();
ss.Read();
xin.code=ss["code"].ToString();
xin.name=ss["name"].ToString();
}
cnn.Close();
return xin;
} /// <summary>
/// 删除
/// </summary>
/// <param name="name"></param>
public bool delete(string code)
{
bool b = false;
cmd.CommandText = "delete from xinxi where code=@code";
cmd.Parameters.Clear();
cmd.Parameters.Add("@code",code);
cnn.Open();
try//看看有没有出错,即删没删成功
{
cmd.ExecuteNonQuery();
b=true;
}
catch
{
b=false;
}
cnn.Close();
return b;
}
public void quanbu()//查询全部信息
{
cmd.CommandText = "select * from xinxi";
cnn.Open();
SqlDataReader ss = cmd.ExecuteReader();
while (ss.Read())
{
Console.WriteLine(ss[]+" "+ss[]);
}
cnn.Close();
}
public bool update(string code,string name)
{
bool b = false;
cmd.CommandText = "update xinxi set name=@name where code=@code";
cmd.Parameters.Clear();
cmd.Parameters.Add("@name",name);
cmd.Parameters.Add("@code",code);
cnn.Open();
try
{
cmd.ExecuteNonQuery();
b = true;
}
catch { }
cnn.Close();
return b;
}
}
}

3,在main函数里面,增删改查

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using ConsoleApplication71.App_Code; namespace ConsoleApplication71
{
class Program
{
static void Main(string[] args)
{
xinxidata sj = new xinxidata();//实例化
#region 添加
//xinxi xin = new xinxi();
//Console.Write("请输入添加的编号:");
//xin.code = Console.ReadLine();
//Console.Write("请输入添加的名字:");
//xin.name = Console.ReadLine();
//sj.insert(xin);
#endregion #region 删除
//Console.Write("请输入被删除编号");
//string code = Console.ReadLine();
//if (sj.chaxun(code) != null)//判断是否有这个编号
//{
// bool T= sj.delete(code);
// if (T == true)//如果删除成功
// {
// Console.WriteLine("删除成功");
// }
// else
// {
// Console.WriteLine("删除不成功");
// }
//}
//else
//{
// Console.WriteLine("输入有误!!");
//}
#endregion
#region 查询全部信息
//sj.quanbu();
#endregion #region 修改
Console.Write("请输入要修改的编号:");
string code = Console.ReadLine();
if (sj.chaxun(code) != null)
{
Console.Write("请输入要修改的名字:");
string name = Console.ReadLine();
bool M= sj.update(code,name);
if (M == true)
{
Console.WriteLine("修改成功!");
}
else
{
Console.WriteLine("删除不成功");
} }
else
{
Console.WriteLine("输入有误,不存在此编号!!");
}
#endregion
Console.ReadLine();
} }
}

完!!

ADO,NET 实体类 和 数据访问类的更多相关文章

  1. ado&period;net 实体类&lowbar;数据访问类

    实体类: using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace ...

  2. ADO&period;NET&lpar;完整修改和查询、实体类,数据访问类&rpar;

    一.完整修改和查询 在编写c#语句时需考虑到用户体验,例如在编写修改语句时,需要考虑到输入的内容在数据库中是否能够找到. 中间变量运用. 1.先查 2.执行操作 完整修改语句: bool has = ...

  3. 9&lowbar;13学习完整修改和查询&amp&semi;&amp&semi;实体类,数据访问类

    完整修改和查询:中间变量运用. 1.先查 2.执行操作 ---------------------------------------------------- namespace ADO.NET_小 ...

  4. C&num;-ade&period;net-实体类、数据访问类

    实体类.数据访问类 是由封装演变而来,使对数据的访问更便捷,使用时只需要调用即可,无需再次编写代码 实体类是按照数据库表的结构封装起来的一个类 首先,新建文件夹 App_Code ,用于存放数据库类等 ...

  5. ADO&period;net 实体类 、数据访问类

    程序分三层:界面层.业务逻辑层.数据访问层 比较规范的写程序方法,要把业务逻辑层和数据访问层分开,此时需要创建实体类和数据访问类 实体类: 例 using System; using System.C ...

  6. 【2017-04-20】Ado&period;Net与面向对象结合架构中的数据访问层(实体类,数据访问类)

    开发项目三层架构:界面层.业务逻辑层.数据访问层 今天学习一下数据访问层,分为实体类和数据访问类 所有的类放在App_Code这个文件夹下边.养成一个好的习惯. 一.实体类 数据库中的表映射为一个类, ...

  7. 【2017-04-20】Sql字符串注入式攻击与防御,实体类,数据访问类

    字符串攻击 所谓sql字符串注入式攻击就是在用户输入界面输入通过精心编制的含有某种指令的字符串,来改变C#中连接数据库要执行的sql语句,从而对数据库进行攻击性操作 在用户输入界面输入  a');up ...

  8. ADO&period;NET 【实体类】【数据访问类】

    认识分层结构,分层式结构是最常见,也是最重要的一种结构. 三层架构(3-tier architecture) 界面层(User Interface layer) 主要对用户的请求接受,以及数据的返回, ...

  9. ADO&period;NET&lpar;一&rpar; 空间 ADO&period;NET结构 命名空间&lpar;车延禄&rpar; System&period;Data—— 所有的一般数据访问类 S&lpar;转载&rpar;

    ADO.NET(一) 空间   ADO.NET结构 命名空间(车延禄)System.Data—— 所有的一般数据访问类System.Data.Common—— 各个数据提供程序共享(或重写)的类Sys ...

随机推荐

  1. Effective C&plus;&plus; 34 区分接口继承和实现继承

    public继承从根本上讲,有两部分:接口继承和实现继承.两者之前的区别很像函数声明与函数定义. 具体设计中,会呈现三种形式:derived class只继承成员函数的接口(纯虚函数):derived ...

  2. SQL-Server使用点滴&lpar;一&rpar;

    前言 SQL的语法比较简单,学起来相比界面UI控制要简单得多,但是SQL在企业级应用中又是如此的重要,以至于很多开发人员都把重点放在SQL上. SQL并没有面向对象的概念,最复杂的设计也不过是表值函数 ...

  3. WCF错误:413 Request Entity Too Large

    在我们用WCF传输数据的时候,如果启用默认配置,传输的数据量过大,经常会出这个错误. WCF包含服务端与客户端,所以这个错误可能出现在服务端返回数据给客户端,或客户端传数据给服务端时. 1. 服务端返 ...

  4. Hadoop 2&period;6&period;4单节点集群配置

    1.安装配置步骤 # wget http://download.oracle.com/otn-pub/java/jdk/8u91-b14/jdk-8u91-linux-x64.rpm # rpm -i ...

  5. Java-JDK配环境,eclipse工具认识

    一.JDK配环境: 1.JDK思维导图 2.测试代码: 需要注意点位类名大小写的区分,符号为英式输入法下的, ; . class Hello{ public static void main(Stri ...

  6. IT公司100题-3-求数组的最大子序列的和

    问题描述: 输入一个整形数组,数组里有正数也有负数. 数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和. 求所有子数组的和的最大值.要求时间复杂度为O(n). 例如输入的数组为1, -2 ...

  7. 控制 WAP 网站上输入框的默认类型

    比如手机号,卡输入框应该默认显示数字键盘,邮箱输入框应该默认显示邮箱键盘.www . c s d n 1 2 3 . com/html/itweb/20130802/36036_36043_36004 ...

  8. zoj1108 FatMouse's Speed

    给你每个物体两个参数,求最长的链要求第一个参数递增,第二个参数递减,要求输出任意最长路径. 首先第一反应根据第二个参数排个序,然后不就是最长上升子序列的问题吗? O(nlogn)的复杂度,当然这样可以 ...

  9. SharePoint 2010 BCS - 概要

    博客地址 http://blog.csdn.net/foxdave SharePoint 2010首次引入了BCS的概念 - Business Connectivity Service.即业务连接服务 ...

  10. springboot 入门四-时间类型处理

    springboot 自带了jackson来处理时间,但不支持jdk8 LocalDate.LocalDateTime的转换. 对于Calendar.Date二种日期,转换方式有二种: 一.统一app ...