Esempio n. 1
0
        /// <summary>
        /// [Chuc.Nguyen] - Chạy câu query theo keyword sử dụng Store
        /// </summary>
        /// <param name="keyword">Từ khóa lấy dữ liệu: có thể là ListId, Id, có thể là Text...</param>
        /// <param name="storeName">Tên store lấy dữ liệu</param>
        /// <param name="status">Trạng thái lấy thành công hoặc lỗi</param>
        /// <returns></returns>
        public IQueryable <TEntity> ExecuteQuery(object keyword, string storeName, string userLogin, ref string status)
        {
            try
            {
                #region Parameter

                var storeItem     = storeName.Split('@');
                var strParameter  = string.Empty;
                var strParameter1 = string.Empty;
                var strParameter2 = "UserName";
                if (storeItem.Length > 1)
                {
                    //storeName: "exec hrm_att_sp_get_Att_GradeById @Id"
                    strParameter = storeItem[1];
                }
                else
                {
                    //storeName: "begin ATT_SP_GET_GRADEBYID(:Id,:R_Output); end;"
                    var n  = storeName.IndexOf('(');
                    var n1 = storeName.IndexOf(')');
                    var n2 = storeName.IndexOf(',');
                    if (n >= 0)
                    {
                        strParameter  = storeName.Substring(n + 2, n2 - (n + 2));
                        strParameter1 = storeName.Substring(n2 + 2, n1 - (n2 + 2));
                    }
                }

                #endregion

                IQueryable <TEntity> listEntity;
                if (Common.UseDataBaseName == DATABASETYPE.ORACLE.ToString())
                {
                    OracleParameter paraKeyword = new OracleParameter();
                    OracleParameter paraUser    = new OracleParameter();
                    if (keyword != null && keyword.GetType() == typeof(string))
                    {
                        paraKeyword.ParameterName = strParameter;
                        paraKeyword.Value         = keyword;
                        paraKeyword.OracleDbType  = OracleDbType.NVarChar;
                    }
                    else
                    {
                        paraKeyword.ParameterName = strParameter;
                        paraKeyword.Value         = keyword;
                        paraKeyword.OracleDbType  = OracleDbType.Object;
                        paraKeyword.DbType        = DbType.Object;
                    }


                    if (ListUtility.CheckStoreNamePermisson(storeName))
                    {
                        storeName  = storeName.Replace(":R_Output", ":UserName, :R_Output");
                        listEntity = UnitOfWork.Context.Database.SqlQuery <TEntity>(storeName,
                                                                                    paraKeyword,
                                                                                    new OracleParameter()
                        {
                            ParameterName = strParameter2,
                            Value         = userLogin,
                            OracleDbType  = OracleDbType.NVarChar,
                        },
                                                                                    new OracleParameter()
                        {
                            ParameterName = strParameter1,
                            OracleDbType  = OracleDbType.Cursor,
                            Direction     = System.Data.ParameterDirection.Output
                        }
                                                                                    ).AsQueryable();
                    }
                    else
                    {
                        listEntity = UnitOfWork.Context.Database.SqlQuery <TEntity>(storeName,
                                                                                    paraKeyword,
                                                                                    new OracleParameter()
                        {
                            ParameterName = strParameter1,
                            OracleDbType  = OracleDbType.Cursor,
                            Direction     = System.Data.ParameterDirection.Output
                        }
                                                                                    ).AsQueryable();
                    }
                }
                else
                {
                    SqlParameter paraKeyword = new SqlParameter();
                    if (keyword != null && keyword.GetType() == typeof(string))
                    {
                        paraKeyword.ParameterName = strParameter;
                        paraKeyword.DbType        = DbType.String;
                    }
                    else if (keyword != null && keyword.GetType() == typeof(Guid))
                    {
                        paraKeyword.ParameterName = strParameter;
                        paraKeyword.DbType        = DbType.Guid;
                    }
                    else
                    {
                        paraKeyword.ParameterName = strParameter;
                        paraKeyword.DbType        = DbType.Object;
                    }
                    paraKeyword.Value = keyword == null ? DBNull.Value : keyword;
                    listEntity        = UnitOfWork.Context.Database.SqlQuery <TEntity>(storeName, paraKeyword).AsQueryable();
                }
                status = NotificationType.Success.ToString();
                return(listEntity);
            }
            catch (Exception ex)
            {
                status = NotificationType.Error + "," + ex.Message;
                return(null);
            }
        }
Esempio n. 2
0
        /// <summary>
        /// [Chuc.Nguyen] - Chạy câu query theo cặp Parameter sử dụng Store
        /// </summary>
        /// <param name="listParameter">Danh sách parameter</param>
        /// <param name="storeName">Tên store lấy dữ liệu</param>
        /// <param name="useCursor">Cho biết có sử dụng biến Out với Oracle</param>
        /// <param name="status">Trạng thái lấy thành công hoặc lỗi</param>
        /// <returns></returns>
        public IQueryable <TEntity> ExecuteQuery(List <object> listParameter, string storeName, bool useCursor, string userLogin, ref string status)
        {
            try
            {
                string strQuery         = string.Empty;
                var    parameterObjects = new List <object>();

                if (!string.IsNullOrEmpty(storeName))
                {
                    if (Common.UseDataBaseName == DATABASETYPE.ORACLE.ToString())
                    {
                        if (storeName.Contains("begin"))
                        {
                            storeName = storeName.Substring(5, storeName.IndexOf('(') - 5);
                        }
                        strQuery = "begin " + storeName + "(";
                        for (int i = 0; i < listParameter.Count; i++)
                        {
                            var strParameter = listParameter[i];
                            strQuery += ":parameter" + i;
                            if (i != listParameter.Count - 1)
                            {
                                strQuery += ",";
                            }
                            var parameter = new OracleParameter
                            {
                                ParameterName = "parameter" + i,
                                Value         = strParameter,
                                OracleDbType  = OracleDbType.Object,
                                DbType        = DbType.Object
                            };
                            if (strParameter != null)
                            {
                                if (!Common.IsAscii(strParameter.ToString()))
                                {
                                    parameter.OracleDbType = OracleDbType.NVarChar;
                                }
                            }
                            parameterObjects.Add(parameter);
                        }
                        if (ListUtility.CheckStoreNamePermisson(storeName))
                        {
                            strQuery += ",:UserName";
                            var para = new OracleParameter();
                            para.ParameterName = "UserName";
                            para.Value         = userLogin;
                            para.DbType        = System.Data.DbType.String;
                            para.OracleDbType  = OracleDbType.NVarChar;
                            parameterObjects.Add(para);
                        }
                        if (useCursor)
                        {
                            strQuery += ",:R_Output";
                            var parameter = new OracleParameter
                            {
                                ParameterName = "R_Output",
                                OracleDbType  = OracleDbType.Cursor,
                                Direction     = System.Data.ParameterDirection.Output
                            };
                            parameterObjects.Add(parameter);
                        }
                        strQuery += "); end;";
                    }
                    else
                    {
                        if (!storeName.Contains("exec"))
                        {
                            strQuery = "exec " + storeName + " ";
                        }
                        else
                        {
                            strQuery = storeName + " ";
                        }

                        for (int i = 0; i < listParameter.Count; i++)
                        {
                            strQuery += "@parameter" + i;
                            if (i != listParameter.Count - 1)
                            {
                                strQuery += ",";
                            }
                            var parameter = new SqlParameter
                            {
                                ParameterName = "parameter" + i,
                                Value         = listParameter[i] ?? DBNull.Value
                            };

                            parameterObjects.Add(parameter);
                            //  parameterObjects.Add(parameter);
                        }
                    }
                }
                status = NotificationType.Success.ToString();
                return(UnitOfWork.Context.Database.SqlQuery <TEntity>(strQuery, parameterObjects.ToArray()).AsQueryable());;
            }
            catch (Exception ex)
            {
                status = NotificationType.Error + "," + ex.Message;
                return(null);
            }
        }