日期:2014-05-17  浏览次数:20554 次

一个菜鸟的SQL拼接类,请高中低手点评.只要能让我进步!谢谢!
有时做一些页面的查询,重复性高。所以有了下面的模块,这只是一小部分.
我省略了一些汇总和排序的功能。这个的一个类,我知道很简单,希望大虾
能给出一些建议。

public class SqlBuilder
{
    private List<CheckBox> _ckbColumns;
    private List<CheckBox> _ckbCondtions;
    private List<string> _conditions;
    private string _tablename;
    public SqlBuilder()
    {
        _ckbColumns = new List<CheckBox>();
        _ckbCondtions = new List<CheckBox>();
        _conditions = new List<string>();
    }
    public void AddCheckBoxColumn(CheckBox item)
    {
        _ckbColumns.Add(item);
    }
    public void AddCheckBoxCondition(CheckBox item,string condition)
    {
        _ckbCondtions.Add(item);
        _conditions.Add(condition);
    }
        public string SQL
    {
        get
        {
            
            StringBuilder sbCondition = new StringBuilder();
            StringBuilder sbColumns = new StringBuilder();
          
            string sql;
            int i = 0;
      
            foreach (CheckBox ckbColumn in _ckbColumns)
            {
                if (ckbColumn.Checked)
                    sbColumns.Append("," + ckbColumn.Text);

            }
            sbCondition.Append(" where 1 = 1 "); 

            foreach (CheckBox ckbCondition in _ckbCondtions)
            {
                if (ckbCondition.Checked)
                {    sbCondition.Append(" and " + ckbCondition.Text + " = N'" +   _conditions[i].Trim() + "'");
                i++;
}