在做三层架构的时候,特别是对表做查询的时候,有时候并不确定查询条件的个数,比如查询学生表:有可能只输入学号,或者姓名,或者性别,总之查询条件的参数个数并不确定,下面是我用List实现传值的代码:

附图如下:

在这里附上数据库的表结构:

CREATE TABLE Student(
        StuId        VARCHAR(6) PRIMARY KEY,
        StuName   VARCHAR(10) NOT NULL,
        MajorId     INT NOT NULL,
        Sex           VARCHAR(2) NOT NULL DEFAULT '男',
        Birthdate   SMALLDATETIME NOT NULL,
        Credit        FLOAT,
        Remark     VARCHAR(200)
)

------------------------------------------------------------------------------------------------

程序代码如下:

Model层----------------------------------------------包含两个类------------------------

------------------表的实体类Student-----------------

public class Student
    {
        private string stuId; 
        public string StuId
        {
            get { return stuId; }
            set { stuId = value; }
        }

private string stuName;

public string StuName

{

get { return stuName; }

set { stuName = value; }

}

private int majorId;

public int MajorId

{

get { return majorId; }

set { majorId = value; }

}

private string sex;

public string Sex

{

get { return sex; }

set { sex = value; }

}

private DateTime birthdate;

public DateTime Birthdate

{

get { return birthdate; }

set { birthdate = value; }

}

private float credit;

public float Credit

{

get { return credit; }

set { credit = value; }

}

private string remark;

public string Remark

{

get { return remark; }

set { remark = value; }

}

}

------------------Condition主要用于传递参数,这个类也可以定义在别的地方-------------------

public class Condition
    {
        public string paramName { get; set; }
        public string paramValue { get; set; }
        public ConditionOperate Operation { get; set; }

// 查询所用到的运算操作符
        public enum ConditionOperate : byte
        {
            Equal,           // 等于
            NotEqual,      // 不等于
            Like,             // 模糊查询
            Lessthan,      // 小于等于
            GreaterThan  // 大于
        }
    }

---------------------DAL层-----------------------------------------------------------------

------------------DBHelper类---------------------------------------------

public class DBHelper

{

private SqlConnection conn;

private SqlCommand cmd;

private SqlDataAdapter sda;

private DataSet ds;

public DBHelper()

{

conn = new SqlConnection(ConfigurationManager.ConnectionStrings["key"].ConnectionString);

}

// 不带参数的查询

public DataSet GetResult(string sql, CommandType type)

{

cmd = new SqlCommand(sql, conn);

sda = new SqlDataAdapter(cmd);

conn.Close();

ds = new DataSet();

sda.Fill(ds, "student");

return ds;

}

// 带参数的查询

public DataSet GetResult(string sql, CommandType type, params SqlParameter[] paras)

{

cmd = new SqlCommand(sql, conn);

if (type == CommandType.StoredProcedure)

{

cmd.CommandType = CommandType.StoredProcedure;

}

cmd.Parameters.AddRange(paras);

sda = new SqlDataAdapter(cmd);

conn.Close();

ds = new DataSet();

sda.Fill(ds, "student");

return ds;

}

}

-----------------------------对Student表操作类

public class StudenDAL

{

public DataSet GetStudent(List<Condition> condition)

{

DataSet ds = new DataSet();

DBHelper db = new DBHelper();

string sql = "select * from student";

// 如果带查询语句带参数

if (condition.Count > 0)

{

sql += SqlString(condition);

ds = db.GetResult(sql, CommandType.Text, SqlParas(condition));

}

else

{

ds = db.GetResult(sql, CommandType.Text);

}

return ds;

}

----------------------以下两个可以写成一个类,以便如果有多张表时,可以实现代码的复用----------------------------------

// 获取查询参数

public SqlParameter[] SqlParas(List<Condition> cond)

{

List<SqlParameter> paras = new List<SqlParameter>();

for (int i = 0; i < cond.Count; i++)

{

SqlParameter para = new SqlParameter("@" + cond[i].paramName, cond[i].paramValue);

if (cond[i].Operation == Condition.ConditionOperate.Like)

{

para.SqlValue = "%" + cond[i].paramValue + "%";

}

paras.Add(para);

}

return paras.ToArray();

}

// 获取SQL查询语句的where子句

public string SqlString(List<Condition> cond)

{

string sqlWhere = string.Empty;

List<string> where = new List<string>();

// 数组元素的顺序应该与ConditionOperate枚举值顺序相同

string[] operateType = { " = ", " <> ", " Like ", " <= ", " >= " };

for (int i = 0; i < cond.Count; i++)

{

int index = (int)cond[i].Operation;

where.Add(string.Format("{0}" + operateType[index] + "{1}", cond[i].paramName, "@" + cond[i].paramName));

}

sqlWhere = " where " + string.Join(" and ", where.ToArray());

return sqlWhere;

}

}

------------------------------BLL层---------------------------

public class StudentBLL
    {
        private readonly StudenDAL stuDal = new StudenDAL();
        public DataSet GetStudent(List<Condition> condition)
        {
            return stuDal.GetStudent(condition);
        }
    }

------------------------------UI层,查询按钮的单击事件-------------------------------------

protected void btnSearch_Click(object sender, EventArgs e)

{

Condition condition;

StudentBLL stu = new StudentBLL();

List<Condition> list = new List<Condition>();

if (txtId.Text!="")

{

condition = new Condition()

{

paramName = "stuId",

paramValue = txtId.Text,

Operation = Condition.ConditionOperate.Equal

};

list.Add(condition);

}

if (txtName.Text!="")

{

condition = new Condition()

{

paramName = "stuName",

paramValue = txtName.Text,

Operation = Condition.ConditionOperate.Equal

};

list.Add(condition);

}

if (txtSex.Text != "")

{

condition = new Condition()

{

paramName = "Sex",

paramValue = txtSex.Text,

Operation = Condition.ConditionOperate.Equal

};

list.Add(condition);

}

GridView1.DataSource = stu.GetStudent(list);

GridView1.DataBind();

}

ASP.NET三层架构之不确定查询参数个数的查询的更多相关文章

  1. Asp.Net 三层架构之泛型应用

    一说到三层架构,我想大家都了解,这里就简单说下,Asp.Net三层架构一般包含:UI层.DAL层.BLL层,其中每层由Model实体类来传递,所以Model也算是三层架构之一了,例外为了数据库的迁移或 ...

  2. asp.net三层架构 及其中使用泛型获取实体数据介绍

    asp.net中使用泛型获取实体数据可以发挥更高的效率,代码简洁方便,本例采用三层架构.首先在model层中定义StuInfo实体,然后在 DAL层的SQLHelper数据操作类中定义list< ...

  3. 新闻公布系统 (Asp.net 三层架构 )

    2012年度课程设计---新闻公布系统(小结)                                                                             ...

  4. ASP.NET三层架构的分析

    BLL   是业务逻辑层   Business   Logic   Layer DAL   是数据访问层   Data   Access   Layer ASP.NET的三层架构(DAL,BLL,UI ...

  5. ASP.NET三层架构项目创建流程

    1.进入VS2010,新建项目—>Visual C#—>Web—>ASP.NET空Web应用程序,如图所示: 2.在解决方案处右击—>新建项目—>Windows—> ...

  6. 三层架构的一点理解以及Dapper一对多查询

    1.首先说一下自己对三层架构的一点理解 论坛里经常说会出现喜欢面相对象的写法,所以使用EF的,我个人觉得他俩没啥关系,先别反对,先听听我怎么说吧. 三层架构,基本都快说烂了,但今天还是说三层架构:UI ...

  7. 初学者-asp.net三层架构

    一.概述: 通常意义上的三层架构就是将整个业务应用划分为:表现层(UI).业务逻辑层(BLL).数据访问层(DAL).区分层次的目的即为了“高内聚,低耦合”的思想.是一种总体设计的思想. 1.表现层( ...

  8. asp.net三层架构详解

    一.数据库 /*==============================================================*/ /* DBMS name:      Microsof ...

  9. asp.net三层架构详解(转)

    摘自:http://www.cnblogs.com/cresuccess/archive/2008/12/10/1351675.html 一.数据库             ,)   )     no ...

随机推荐

  1. iOS app 程序启动原理

    iOS app 程序启动原理 Info.plist: 常见设置     建立一个工程后,会在Supporting files文件夹下看到一个"工程名-Info.plist"的文件, ...

  2. C#对七牛云的操作

    1.配置环境 项目中引用 QiNiu.4.0.dll 在webconfig:<add key="USER_AGENT" value="qiniu csharp-sd ...

  3. 我心中的核心组件(可插拔的AOP)~调度组件quartz.net

    回到目录 quartz.net是一个任务调度组件,它可以灵活的设置你的调试方式,按时间,按日期,按周期都可以很容易的实现,quartz不仅可以用在web中,而且还可以部署在winform,winser ...

  4. Atitti knn实现的具体四个距离算法 欧氏距离、余弦距离、汉明距离、曼哈顿距离

    Atitti knn实现的具体四个距离算法  欧氏距离.余弦距离.汉明距离.曼哈顿距离 1. Knn算法实质就是相似度的关系1 1.1. 文本相似度计算在信息检索.数据挖掘.机器翻译.文档复制检测等领 ...

  5. JavaScript函数后面加不加括号的区别

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  6. [java]输入一个算术表达式输出结果

    动手有益. 输入一个表达式,没有括号,数字小于0-9之间,输出计算结果,所有的中间结果化为整形.例如:  输入:3+8×2/9-2  输出:2 /** * input a calculate stri ...

  7. Windows Server 2012 R2 里面如何安装Net Framework 3.5

    图示 不要慌,和windows是不一样的,没有问题 下一步 默认即可,下一步 这里面的东西以后会装,先不管,我们今天目的是装 net framework 3.5 选一下 正在安装 如果出错了请参考: ...

  8. 使用Source Safe for SQL Server解决数据库版本管理问题

    简介     在软件开发过程中,版本控制是一个广为人知的概念.因为一个项目可能会需要不同角色人员的参与,通过使用版本控制软件,可以使得项目中不同角色的人并行参与到项目当中.源代码控制使得代码可以存在多 ...

  9. jsp获得文件的绝对路径

    当前WEB应用的物理路径:<%=application.getRealPath("/")%>当前访问的JSP文件的物理路径:<%=application.getR ...

  10. Cwinux源码解析(五)

      Cwinux源码解析(五)