zoukankan      html  css  js  c++  java
  • RSqlBuilder

    这是一篇运用在MyFrameWork(YZR框架)上的RSqlBuilder类的介绍,它主要是对Sql语句的补充支持,在RPro之外以链式编程,类似于数据访问层的方式存在。

    1.开始之前先说明一下IDataBase 接口,RPro 类。

    IDataBase action = RUtility.Instance.GetDbUtility(TableName);

    获得的就是框架的数据操作类(RAction,RMotion),IDataBase 目前兼容Oracle和SqlServer数据库.

    RPro rp = new RPro([_dbUtility]);

    获取的就是框架存储过程以及Sql的操作类,RPro目前兼容Oracle和SqlServer数据库。(对于sql语句需要开发者根据自己选择的数据库进行编写相应的sql格式)

    2.进入主题

     RSqlBuilder是对RPro的补充,能统一Sql语句(不区别数据库,写法一样),支持链接编程,支持AOP拦截。(目前版本只用于查询 ,不用于新增,删除,更新)

    RRunnable run = rp.ExecuteQuerySqlBuilder(rsb);

    返回的结果是RRunnable对象,主要的目的是为了更好的获取运行结果,RRunnable类有相应的异常处理以及内置数据转化器(List,DataTable,Int,String等)

    namespace YZR.Data
    {
        using System.Collections;
        using System.Reflection;
        /// <summary>
        /// Create By YZR   2016.03.01
        /// 用于查询  不用于新增,删除,更新
        /// </summary>
        public sealed class RSqlBuilder
        {
            private string actionName;
    
            public string ActionName
            {
                get { return actionName; }
                set { actionName = value; }
            }
            private string columnName;
    
            public string ColumnName
            {
                get { return columnName; }
                set { columnName = value; }
            }
    
            private string colName;//作为子查询的别名列
    
            public string ColName
            {
                get { return colName; }
                set { colName = value; }
            }
            private string dataSource;
    
            public string DataSource
            {
                get { return dataSource; }
                set { dataSource = value; }
            }
            private string tableName;
    
            public string TableName
            {
                get { return tableName; }
                set { tableName = value; }
            }
            private List<IRWhere> wheres;
    
            public List<IRWhere> Wheres
            {
                get { return wheres; }
                set { wheres = value; }
            }
            private RSqlBuilder rsb;//作为内置子查询对象
    
            public RSqlBuilder Rsb
            {
                get { return rsb; }
                set { rsb = value; }
            }
            private QueryPattern pattern = QueryPattern.Where;
    
            public QueryPattern Pattern
            {
                get { return pattern; }
                set { pattern = value; }
            }
            private bool isSubQuery = false;
    
            public bool IsSubQuery
            {
                get { return isSubQuery; }
                set { isSubQuery = value; }
            }
    
            private bool isJoinQuery = false;
    
            public bool IsJoinQuery
            {
                get { return isJoinQuery; }
                set { isJoinQuery = value; }
            }
            public JoinClass jc { get; set; }
    
            public RRunnable innerRunnable { get; set; }
    
            private RSqlBuilder innerRsqlBuilder;
    
            public RSqlBuilder InnerRsqlBuilder
            {
                get { return innerRsqlBuilder; }
                set { innerRsqlBuilder = value; }
            }
            private int topCount;
    
            private string orderColumn;
    
            private OrderType orderType;//排序方式
    
            private Pager pager;
    
            public Pager Pager
            {
                get { return pager; }
                set { pager = value; }
            }
            private bool QueryTotalCount = false;
            private List<IRWhere> countWheres;
            private bool QueryDistinct = false;
    
            public RSqlBuilder()
            {
                this.innerRsqlBuilder = this;
            }
            public RSqlBuilder(string _actionName, string _columnName, string _dataSource)
            {
                this.actionName = _actionName;
                this.columnName = _columnName;
                this.dataSource = _dataSource;
                this.innerRsqlBuilder = this;
            }
            public RSqlBuilder(string _actionName, string _columnName, string _dataSource, List<IRWhere> wheres)
            {
                this.actionName = _actionName;
                this.columnName = _columnName;
                this.dataSource = _dataSource;
                this.wheres = wheres;
                this.innerRsqlBuilder = this;
            }
            public RSqlBuilder(string _actionName, string _columnName, string _dataSource, string tableName)
            {
                this.actionName = _actionName;
                this.columnName = _columnName;
                this.dataSource = _dataSource;
                this.tableName = tableName;
                this.innerRsqlBuilder = this;
            }
            public RSqlBuilder(string _actionName, string _columnName, string _dataSource, string tableName, List<IRWhere> wheres)
            {
                this.actionName = _actionName;
                this.columnName = _columnName;
                this.dataSource = _dataSource;
                this.tableName = tableName;
                this.wheres = wheres;
                this.innerRsqlBuilder = this;
            }
            /// <summary>
            /// 
            /// </summary>
            /// <param name="_actionName"></param>
            /// <param name="_columnName"></param>
            /// <param name="_colName">作为where语句的 列名 in (....)</param>
            /// <param name="_dataSource"></param>
            /// <param name="tableName"></param>
            /// <param name="wheres"></param>
            /// <param name="rsb"></param>
            /// <param name="qp"></param>
            public RSqlBuilder(string _actionName, string _columnName, string _colName, string _dataSource, string tableName, List<IRWhere> wheres, RSqlBuilder rsb, QueryPattern qp)
            {
                this.actionName = _actionName;
                this.columnName = _columnName;
                this.dataSource = _dataSource;
                this.tableName = tableName;
                this.wheres = wheres;
                this.rsb = rsb;
                this.Pattern = qp;
                this.isSubQuery = true;
                this.innerRsqlBuilder = this;
                this.colName = _colName;
            }
            public RSqlBuilder(string _actionName, string _columnName, string tableName, List<IRWhere> wheres, RSqlBuilder rsb, QueryPattern qp)
            {
                this.actionName = _actionName;
                this.columnName = _columnName;
                this.tableName = tableName;
                this.wheres = wheres;
                this.rsb = rsb;
                this.Pattern = qp;
                this.isSubQuery = true;
                this.innerRsqlBuilder = this;
            }
    
            public void ToSql()
            {
                Rsql rs = new Rsql();
                if (IsJoinQuery)
                {
                    rs.JObject = jc;
                    //rs.IsJoinQuery = true;
                    rs.IsJoinQuery = IsJoinQuery;
                    //isJoinQuery = false;//完成传导之后恢复isJoinQuery值
                    rs.ActionName = RAopEnum.Select.ToString();
                    rs.ColumnName = jc.ColumnName;
                    rs.DataSource = jc.MainTableName + "-" + jc.JoinTableName;
                    rs.TableName = null;
                    rs.Wheres = jc.Wheres;
    
                }
                else
                {
                    rs.ActionName = this.actionName;
                    rs.ColumnName = this.columnName;
                    rs.DataSource = this.dataSource;
                    rs.TableName = this.tableName;
                    rs.Wheres = this.wheres;
                    rs.subRsb = this.rsb;
                    rs.pattern = this.pattern;
                }
                rs.IsSubQuery = this.isSubQuery;
                rs.TopCount = innerRsqlBuilder.topCount;
                rs.orderType = innerRsqlBuilder.orderType;
                rs.OrderColumn = innerRsqlBuilder.orderColumn;
                rs.innerPager = innerRsqlBuilder.pager;
                rs.QueryTotalCount = innerRsqlBuilder.QueryTotalCount;
                rs.QueryDistinct = innerRsqlBuilder.QueryDistinct;
                rs.IsToSql = true;
                _rsqlExpress = rs;
            }
            public void SetAction(RAopEnum rEnum)
            {
                this.actionName = rEnum.ToString();
            }
            public void SetColumn(string[] colNames)
            {
                StringBuilder _colNames = new StringBuilder();
                if (colNames.Length <= 0)
                {
                    this.columnName = "*";
                    return;
                }
                foreach (string item in colNames)
                {
                    _colNames.Append(item + ",");
                }
                _colNames = _colNames.Remove(_colNames.Length - 1, 1);
                this.columnName = _colNames.ToString();
            }
            public void SetColumn(string colNames)
            {
                this.columnName = colNames;
            }
            public void SetColumn()
            {
                this.columnName = "*";
            }
            public void SetDataSoruce(TableNames tableName)
            {
                this.dataSource = tableName.ToString();
            }
    
            private Rsql _rsqlExpress = new Rsql();
    
            public Rsql RsqlExpress
            {
                get { return _rsqlExpress; }
                set { _rsqlExpress = value; }
            }
    
            static RSqlBuilder()
            {
    
            }
    
            public static RSqlBuilder Join(string table1, string table2, List<OnKey> list, List<IRWhere> wheres)//考虑返回值,链表操作
            {
                string[] names = new string[2] { table1, table2 };
                Dictionary<string, string> dic = new Dictionary<string, string>();
                RSqlBuilder rsb = new RSqlBuilder();
                if (table1 == table2)
                {
                    dic.Add("ERROR", "表名出现异常");
                    RRunnable run = new RRunnable("表名重复", 0, dic);
    
    
                    rsb.innerRunnable = run;
                    return rsb;
                }
                return Join(names, list, wheres);
            }
            private static bool func(string[] tableNames)
            {
                ArrayList al = new ArrayList();
                foreach (string item in tableNames)
                {
                    if (al.Contains(item))
                    {
                        return true;
                    }
                    else
                    {
                        al.Add(item);
                    }
                }
                return false;
            }
            public static RSqlBuilder Join(string[] tableNames, List<OnKey> list, List<IRWhere> wheres)
            {
    
                Dictionary<string, string> dic = new Dictionary<string, string>();
                RSqlBuilder rsb = new RSqlBuilder();
                if (func(tableNames))
                {
                    dic.Add("ERROR", "表名出现异常");
                    RRunnable run = new RRunnable("表名重复", 0, dic);
    
    
                    rsb.innerRunnable = run;
                    return rsb;
                }
    
                if (list == null || list.Any() == false)
                {
                    dic.Add("ERROR", "连接语句的on谓词出现异常");
                    RRunnable run = new RRunnable("on谓词的键值对不能为空,而且个数必须1个或以上", 0, dic);
    
    
                    rsb.innerRunnable = run;
                    return rsb;
                }
                if (tableNames == null || tableNames.Length < 1)
                {
                    dic.Add("ERROR", "表名出现异常");
                    RRunnable run = new RRunnable("表名不能为空,而且个数必须1个或以上", 0, dic);
    
    
                    rsb.innerRunnable = run;
                    return rsb;
                }
    
    
                //连接操作
                JoinClass myJoin = new JoinClass();
                myJoin.MainTableName = tableNames[0];
                //myJoin.JoinTableName = table2;
                myJoin.JoinType = JoinType.Inner;
                myJoin.Wheres = wheres;
                myJoin.ComplexJoin = false;//默认
                string joinTable = string.Empty;
                ArrayList al = new ArrayList();
    
                string onStr = string.Empty;
                if (list != null)
                {
                    if (list.Any())
                    {
                        foreach (OnKey item in list)
                        {
                            onStr += item.MainKey + " = " + item.JoinKey + " and ";
                        }
                    }
                }
                myJoin.OnString = onStr.Substring(0, onStr.Length - 4);
    
                if (tableNames.Length == 1)//内连接
                {
                    dic.Add("ERROR", "不支持自连接");
                    RRunnable run = new RRunnable("不支持自连接", 0, dic);
    
    
                    rsb.innerRunnable = run;
                    return rsb;
    
                    //myJoin.JoinType = JoinType.Self;
                    //myJoin.JoinTableName = myJoin.MainTableName;
                    //myJoin.ColumnName = myJoin.MainTableName + ".*";
                }
                else
                {
                    Type type = typeof(TableNames);
                    string[] tbNames = type.GetEnumNames();
                    bool error = false;
                    foreach (string item in tableNames)
                    {
                        if (tbNames.Contains(item) == false)
                        {
                            error = true;
                            break;
                        }
                    }
                    if (error)
                    {
                        dic.Add("ERROR", "表名输入有误,请检车Entity");
                        RRunnable run = new RRunnable("找不到指定表名", 0, dic);
    
    
                        rsb.innerRunnable = run;
                        return rsb;
                    }
    
    
    
    
                    if (tableNames.Length > 2)
                    {
    
                        myJoin.ComplexJoin = true;
                    }
    
    
                    foreach (string table in tableNames)
                    {
                        if (table != myJoin.MainTableName)
                        {
                            joinTable += table + ",";
    
                        }
                        string path = AppDomain.CurrentDomain.BaseDirectory;
                        Assembly ass = Assembly.LoadFrom(path + "bin\YZR.Entity.dll");
    
    
                        Type t = ass.GetType("YZR.Entity." + table);
                        string[] names = t.GetEnumNames();
                        int i = 0;
                        foreach (string item in names)
                        {
                            bool flag = true;
                            string value = item;
                            string asString = string.Empty;
                            while (flag)
                            {
                                if (al.Contains(value))
                                {
                                    i++;
                                    value = value + i;
                                    asString = item + "  " + value;//别名
    
                                }
                                else
                                {
                                    flag = false;
                                    al.Add(value);
                                }
    
                            }
                            if (string.IsNullOrEmpty(asString))
                            {
                                myJoin.ColumnName += " " + table + "." + value + ",";
                            }
                            else
                            {
                                myJoin.ColumnName += " " + table + "." + asString + ",";
                            }
    
                        }
                    }
                    myJoin.JoinTableName = joinTable.Substring(0, joinTable.Length - 1);
                    myJoin.ColumnName = myJoin.ColumnName.Substring(0, myJoin.ColumnName.Length - 1);
                }
    
    
                //jc = myJoin;
                //isJoinQuery = true;
                RSqlBuilder r = new RSqlBuilder();
                r.IsJoinQuery = true;
                r.jc = myJoin;
                return r;
            }
    
            public static RSqlBuilder Select(string _columnName, string _dataSource, List<IRWhere> wheres)
            {
                return new RSqlBuilder(RAopEnum.Select.ToString(), _columnName, _dataSource, wheres);
            }
            public static RSqlBuilder Select(string _columnName, string _dataSource, string tableName, List<IRWhere> wheres)
            {
                return new RSqlBuilder(RAopEnum.Select.ToString(), _columnName, _dataSource, tableName, wheres);
            }
            /// <summary>
            /// where式子查询
            /// </summary>
            /// <param name="_columnName"></param>
            /// <param name="_colName">作为where语句的 "列名_colName" in (.....)</param>
            /// <param name="_dataSource"></param>
            /// <param name="tableName"></param>
            /// <param name="wheres"></param>
            /// <param name="rsb"></param>
            /// <returns></returns>
            public static RSqlBuilder SubSelectWhere(string _columnName, string _colName, string _dataSource, string tableName, List<IRWhere> wheres, RSqlBuilder rsb)
            {
                return new RSqlBuilder(RAopEnum.Select.ToString(), _columnName, _colName, _dataSource, tableName, wheres, rsb, QueryPattern.Where);
            }
            public static RSqlBuilder SubSelectForm(string _columnName, string tableName, List<IRWhere> wheres, RSqlBuilder rsb)
            {
                return new RSqlBuilder(RAopEnum.Select.ToString(), _columnName, tableName, wheres, rsb, QueryPattern.From);
            }
    
            public RSqlBuilder Top(int count)
            {
                this.innerRsqlBuilder.topCount = count;
                return this.innerRsqlBuilder;
            }
    
    
            public RSqlBuilder OrderByAsc(string Column)
            {
                this.innerRsqlBuilder.orderColumn = Column;
                this.innerRsqlBuilder.orderType = OrderType.Asc;
                return this.innerRsqlBuilder;
            }
            public RSqlBuilder OrderByAsc(Enum Column)
            {
                return OrderByAsc(Column.ToString());
            }
            public RSqlBuilder OrderByDesc(string Column)
            {
                this.innerRsqlBuilder.orderColumn = Column;
                this.innerRsqlBuilder.orderType = OrderType.Desc;
                return this.innerRsqlBuilder;
            }
            public RSqlBuilder OrderByDesc(Enum Column)
            {
                return OrderByDesc(Column.ToString());
            }
            /// <summary>
            /// 分页
            /// </summary>
            /// <param name="colName">所有查询的列</param>
            /// <param name="tableName">别名</param>
            /// <param name="StartIndex">开始索引</param>
            /// <param name="LastIndex">结束索引</param>
            /// <param name="orderCol">排序列,一般主键</param>
            /// <returns></returns>
            public RSqlBuilder Page(string colName, string tableName, int StartIndex, int LastIndex, string orderCol, List<IRWhere> wheres)
            {
                this.innerRsqlBuilder.pager = new Pager(colName, tableName, StartIndex, LastIndex, orderCol, wheres);
                return this.innerRsqlBuilder;
            }
            public RSqlBuilder Page(int PageIndex, int PageSize, string colName, string tableName, string orderCol, List<IRWhere> wheres)
            {
                int StartIndex = (PageIndex - 1) * PageSize;
                int LastIndex = PageIndex * PageSize;
                this.innerRsqlBuilder.pager = new Pager(colName, tableName, StartIndex, LastIndex, orderCol, wheres);
                return this.innerRsqlBuilder;
            }
            /// <summary>
            /// 没有加上wheres
            /// </summary>
            /// <param name="wheres"></param>
            /// <returns></returns>
            public RSqlBuilder Count(List<IRWhere> wheres)
            {
                innerRsqlBuilder.QueryTotalCount = true;
                return innerRsqlBuilder;
            }
            public RSqlBuilder Count()
            {
                innerRsqlBuilder.QueryTotalCount = true;
                return innerRsqlBuilder;
            }
    
            public RSqlBuilder Distinct()
            {
                innerRsqlBuilder.QueryDistinct = true;
                return innerRsqlBuilder;
            }
            public RSqlBuilder Clear()
            {
                return new RSqlBuilder();
            }
        }
        public enum QueryPattern
        {
            From,
            Where
        }
        public class JoinClass
        {
            private string mainTableName;
    
            public string MainTableName
            {
                get { return mainTableName; }
                set { mainTableName = value; }
            }
            private string joinTableName;
    
            public string JoinTableName
            {
                get { return joinTableName; }
                set { joinTableName = value; }
            }
            private JoinType joinType;
    
            public JoinType JoinType
            {
                get { return joinType; }
                set { joinType = value; }
            }
            public string OnString { get; set; }
            private List<IRWhere> wheres;
    
            public List<IRWhere> Wheres
            {
                get { return wheres; }
                set { wheres = value; }
            }
            private string columnName;
    
            public string ColumnName
            {
                get { return columnName; }
                set { columnName = value; }
            }
            private bool complexJoin = false;
    
            public bool ComplexJoin
            {
                get { return complexJoin; }
                set { complexJoin = value; }
            }
    
        }
        public enum JoinType
        {
            Left,
            Right,
            Inner,
            Self
        }
        public class OnKey
        {
            private string mainKey;
    
            public string MainKey
            {
                get { return mainKey; }
                set { mainKey = value; }
            }
            private string joinKey;
    
            public string JoinKey
            {
                get { return joinKey; }
                set { joinKey = value; }
            }
            public OnKey(string mainKey, string joinKey)
            {
                this.mainKey = mainKey;
                this.joinKey = joinKey;
            }
        }
        public enum OrderType
        {
            Asc,
            Desc
        }
        public class Pager
        {
            private string colName;
    
            public string ColName
            {
                get { return colName; }
                set { colName = value; }
            }
            private string tableName;
    
            public string TableName
            {
                get { return tableName; }
                set { tableName = value; }
            }
            private int startIndex;
    
            public int StartIndex
            {
                get { return startIndex; }
                set { startIndex = value; }
            }
            private int lastIndex;
    
            public int LastIndex
            {
                get { return lastIndex; }
                set { lastIndex = value; }
            }
            private string orderCol;
    
            public string OrderCol
            {
                get { return orderCol; }
                set { orderCol = value; }
            }
            private List<IRWhere> wheres;
    
            public List<IRWhere> Wheres
            {
                get { return wheres; }
                set { wheres = value; }
            }
            public Pager(string colName, string tableName, int startIndex, int lastIndex, string orderCol, List<IRWhere> wheres)
            {
                this.colName = colName;
                this.tableName = tableName;
                this.startIndex = startIndex;
                this.lastIndex = lastIndex;
                this.orderCol = orderCol;
                this.wheres = wheres;
            }
        }
    }
    View Code

    3.Demo

            /// <summary>
            /// RSqlBuilder
            /// </summary>
            /// <returns></returns>
            public string RExecute()
            {
                RPro rp = new RPro();
                rp.ROpen();
                List<IRWhere> list = new List<IRWhere>();
                //list.Add(new RWhere(" and ", "UserName", "=", "YZR"));
                list.Add(new RWhere(" and ", TableNames.UserInfo.ToString() + "." + UserInfo.UserID.ToString(), "in", "1,2,3,4"));
                //================Begin SubQuery============================================================
                //RSqlBuilder ParentRsb = new RSqlBuilder(RAopEnum.Select.ToString(), "UserName", "TestTable");
                //操作,列名,数据源,别名,条件
                //RSqlBuilder rsb = new RSqlBuilder(RAopEnum.Select.ToString(), "*","PrizeID", "TestTable", "Alias",null,ParentRsb,QueryPattern.Where);//子查询作为数据源
                //RSqlBuilder rsb = new RSqlBuilder(RAopEnum.Select.ToString(), "*", "Alias", list, ParentRsb, QueryPattern.From);
                //RSqlBuilder rsb = new RSqlBuilder(RAopEnum.Select.ToString(), "*", "TestTable", "Alias", null);
    
                //RSqlBuilder ParentRsb = RSqlBuilder.Select("PrizeID", "Prize",null);
    
                //RSqlBuilder rsb = RSqlBuilder.SubSelectWhere("*", "Prize", "Awards", "Alias", null, ParentRsb);
                //================End SubQuery============================================================
    
                //================Begin Join============================================================
                //RSqlBuilder JRsb = new RSqlBuilder(RAopEnum.Select.ToString(), "UserName", "TestTable","t");
                List<OnKey> keys = new List<OnKey>();
                //写法1
                //string key1=TableNames.Awards.ToString()+".PrizeID";
                //string key2=TableNames.Prize.ToString()+".PrizeID";
                //写法2
                //keys.Add(new OnKey("UserInfo.UserID", "UserInfo.UserID"));
                //keys.Add(new OnKey(TableNames.Awards.ToString() + ".PrizeID", TableNames.Prize.ToString() + ".PrizeID"));
                //keys.Add(new OnKey(TableNames.Awards.ToString() + "."+Awards.PrizeID.ToString(), TableNames.Prize.ToString() + "."+Prize.PrizeID.ToString()));
                //写法3
                keys.Add(new OnKey(TableNames.UserInfo.ToString() + "." + UserInfo.AwardsID.ToString(), TableNames.Awards.ToString() + "." + Awards.AwardsID.ToString()));
                keys.Add(new OnKey(TableNames.UserInfo.ToString() + "." + UserInfo.BranchID.ToString(), TableNames.Branch.ToString() + "." + Branch.BranchID.ToString()));
                //RSqlBuilder不支持自连接
                //RSqlBuilder rsb = RSqlBuilder.Join(new string[1] { TableNames.UserInfo.ToString() }, keys,list);
                //指定两个表名连接
                //RSqlBuilder rsb=RSqlBuilder.Join(TableNames.Awards.ToString(), TableNames.Prize.ToString(), keys,list);
                //构造一个表数组进行连接
                //RSqlBuilder rsb = RSqlBuilder.Join(new string[2] { TableNames.Awards.ToString(), TableNames.Prize.ToString() }, keys,list);
                RSqlBuilder rsb = RSqlBuilder.Join(new string[3] { TableNames.Awards.ToString(), TableNames.UserInfo.ToString(), TableNames.Branch.ToString() }, keys, list);
                //================End Join============================================================
    
                //================Begin Top============================================================
                //普通前几条数据查询
                //RSqlBuilder rsb = RSqlBuilder.Select("*", "UserInfo", "Alias", null).Top(2);
                //连表的前几条数据查询
                //RSqlBuilder rsb = RSqlBuilder.Join(new string[2] { TableNames.Awards.ToString(), TableNames.Prize.ToString() }, keys, null).Top(1);
                //子查询的前几条数据查询
                //RSqlBuilder ParentRsb = RSqlBuilder.Select("PrizeID", "Prize",null);
                //RSqlBuilder rsb = RSqlBuilder.SubSelectWhere("*", "PrizeID", "Awards", "Alias", null, ParentRsb).Top(2);//where子查询
                //RSqlBuilder rsb = RSqlBuilder.SubSelectForm("*", "Alias", null, ParentRsb).Top(2);//Form子查询
                //================End Top============================================================
    
                //================Begin OrderBy============================================================
    //先Top或先OrderBy都没关系
    //前10条的升序排序 //RSqlBuilder rsb = RSqlBuilder.Select("PrizeID", "Prize", null).Top(10).OrderByAsc(Prize.PrizeID); //连表的前几条升序排序 //RSqlBuilder rsb = RSqlBuilder.Join(new string[2] { TableNames.Awards.ToString(), TableNames.Prize.ToString() }, keys, null).Top(5).OrderByAsc(Awards.AwardsID);//最好加上表名作为前缀 //子查询的前几条数据降序排序 //RSqlBuilder ParentRsb = RSqlBuilder.Select("PrizeID", "Prize",null); //RSqlBuilder rsb = RSqlBuilder.SubSelectWhere("*", "PrizeID", "Awards", "Alias", null, ParentRsb).Top(3).OrderByDesc(Prize.PrizeID);//where子查询 //RSqlBuilder rsb = RSqlBuilder.SubSelectForm("*", "Alias", null, ParentRsb).Top(2).OrderByDesc(Prize.PrizeID);//Form子查询 //================End OrderBy============================================================ //注意点,子查询嵌套连表有一些限制 //1.允许将连表的数据(rsb)嵌入到子查询中,但必须先得到连表的JoinRsb,再在另外一个rsb实例中使用JoinRsb(其实就是一句话,子查询和连表不能链式编程) //2.没有实现将子查询数据用去连表操作 //================Begin 分页============================================================ //兼容数据库 //可扩展,更面向对象//RSqlBuilder rsb = RSqlBuilder.Select("PrizeID", "Prize", null).Page("*", "t", 1, 5, "PrizeID",null); //RSqlBuilder rsb = RSqlBuilder.Select("PrizeID", "Prize", null).Page(1, 5,"*", "t", "PrizeID"); //================End 分页============================================================ //================Begin Count============================================================ //RSqlBuilder rsb = RSqlBuilder.Select("PrizeID", "Prize", null).Page("*", "t", 1, 5, "PrizeID", null).Count(); //================End Count============================================================ //================Begin GroupBy============================================================ //================End GroupBy============================================================ //================Begin Distinct============================================================ //注意点: //1.distinct在分页前,不能distinct分页数据 //distinct只作用于内层 //不重复前10条的升序排序 //RSqlBuilder rsb = RSqlBuilder.Select("PrizeID", "Prize", null).Top(10).OrderByAsc(Prize.PrizeID).Distinct(); //连表的前几条升序排序 //RSqlBuilder rsb = RSqlBuilder.Join(new string[2] { TableNames.Awards.ToString(), TableNames.Prize.ToString() }, keys, null).Top(5).OrderByAsc(Awards.AwardsID).Distinct();//最好加上表名作为前缀 //子查询的前几条数据降序排序 //RSqlBuilder ParentRsb = RSqlBuilder.Select("PrizeID", "Prize", null); //RSqlBuilder rsb = RSqlBuilder.SubSelectWhere("*", "PrizeID", "Awards", "Alias", null, ParentRsb).Top(3).OrderByDesc(Prize.PrizeID).Distinct();//where子查询 //RSqlBuilder rsb = RSqlBuilder.SubSelectForm("*", "Alias", null, ParentRsb).Top(2).OrderByDesc(Prize.PrizeID);//Form子查询 //================End Distinct============================================================ //是否跳过aop,默认为false rp.SkipAop = false; if (rsb.innerRunnable != null) { return ""; } //获取rp运行结果 RRunnable run = rp.ExecuteQuerySqlBuilder(rsb); //RRunnable run = rp.ExecuteScalarSqlBuilder(rsb); rp.RClose(); //Result标识运行结果是否正常 if (run.Result == 1) { //获取运行结果的上下文 RContext context = run.getContext(); //通过上下文获取结果集(以集合形式返回) //List<YZR> d = context.getDataSource<YZR>(); //通过上下文获取结果集(以DataTable形式返回) DataTable dt = context.getDataSource2<DataTable>(); int c = dt.Rows.Count; List<Dictionary<string, object>> record = context.getDataSource(); //context = run2.getContext(); //通过上下文获取结果集(以字符串形式返回) //string value = context.getDataSource2<string>(); } else { //运行结果的操作信息 string Error = run.Meassage; //详细信息(json表示) string ErrorJsonString = run.ToString(); //信息数据 Dictionary<string, string> dic = (Dictionary<string, string>)run.Data; //.net framework异常内部信息 Exception ex = run.innerException; } string Result = "{"Text":"Success"}"; return Result; }

    RSqlBuilder在这个版本还是存在很多不足以及问题,以后改动之后会再补充RSqlBuilder的说明。

  • 相关阅读:
    IIS Express 配置缓存位置
    Docker Demo on Docker
    前端的哪些坑
    如何在container中编译dotnet的eShopOnContainers
    JQuery 常用的那些东西
    jQuery选择器大全
    Js 跨域CORS报错 Response for preflight has invalid HTTP status code 405
    WPF 通过透明度遮罩和变换制作倒影效果
    Ons 让人欲哭无泪问题,官方介绍不详
    如何转换任何配置文件 文件中的内容
  • 原文地址:https://www.cnblogs.com/Francis-YZR/p/5386266.html
Copyright © 2011-2022 走看看