Add BetaCalc36,24,06 . Optimize MG
This commit is contained in:
@@ -12,6 +12,7 @@ namespace MarketData.DataAccess
|
||||
private AnalystRatingsDA()
|
||||
{
|
||||
}
|
||||
|
||||
public static AnalystRatings GetAnalystRatings()
|
||||
{
|
||||
MySqlConnection sqlConnection = null;
|
||||
@@ -63,6 +64,7 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
public static AnalystRatings GetAnalystRatings(String symbol, DateTime minDate,DateTime maxDate)
|
||||
{
|
||||
MySqlConnection sqlConnection = null;
|
||||
@@ -119,6 +121,7 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
public static DateTime GetMaxDateNoZacks()
|
||||
{
|
||||
MySqlConnection sqlConnection = null;
|
||||
@@ -150,6 +153,7 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
public static AnalystRatings GetAnalystRatingsMaxDateNoZacks(String symbol,DateTime maxDate)
|
||||
{
|
||||
MySqlConnection sqlConnection = null;
|
||||
@@ -197,6 +201,61 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
public static Dictionary<String,AnalystRatings> GetAnalystRatingsDowngradesMaxDateNoZacks(List<String> symbols,DateTime maxDate)
|
||||
{
|
||||
MySqlConnection sqlConnection = null;
|
||||
MySqlDataReader sqlDataReader = null;
|
||||
MySqlCommand sqlCommand =null;
|
||||
Dictionary<String,AnalystRatings> analystRatings = new Dictionary<String,AnalystRatings>();
|
||||
String strQuery = null;
|
||||
|
||||
try
|
||||
{
|
||||
StringBuilder sb = new StringBuilder();
|
||||
sqlConnection = SqlUtils.CreateMySqlConnection(MainDataSource.Instance.LocateDataSource("market_data"));
|
||||
sb.Append("SELECT B.date, B.symbol,B.company, B.brokerage_firm, B.type, B.ratings_change, B.price_target from ");
|
||||
sb.Append("(SELECT date, symbol, upper(company) AS company, brokerage_firm, TYPE, ratings_change, price_target, ROW_NUMBER() OVER (");
|
||||
sb.Append(" PARTITION BY symbol ORDER BY DATE DESC) AS rownum from analystratings ");
|
||||
sb.Append("WHERE symbol IN ").Append(SqlUtils.CreateInClause(symbols)).Append(" AND date<=").Append(SqlUtils.ToSqlDate(maxDate,true));
|
||||
sb.Append(" AND type='Downgrades')B");
|
||||
sb.Append(" WHERE B.rownum<=1");
|
||||
|
||||
strQuery = sb.ToString(); ;
|
||||
sqlCommand = new MySqlCommand(strQuery, sqlConnection);
|
||||
sqlCommand.CommandTimeout = SqlUtils.COMMAND_TIMEOUT;
|
||||
sqlDataReader = sqlCommand.ExecuteReader();
|
||||
while (sqlDataReader.Read())
|
||||
{
|
||||
AnalystRating analystRating = new AnalystRating();
|
||||
analystRating.Date = sqlDataReader.GetDateTime(0);
|
||||
analystRating.Symbol = sqlDataReader.GetString(1);
|
||||
analystRating.CompanyName = sqlDataReader.GetString(2);
|
||||
analystRating.BrokerageFirm = sqlDataReader.GetString(3);
|
||||
analystRating.Type = sqlDataReader.GetString(4);
|
||||
analystRating.RatingsChange = sqlDataReader.GetString(5);
|
||||
if (!sqlDataReader.IsDBNull(6)) analystRating.PriceTarget = sqlDataReader.GetDouble(6);
|
||||
if(!analystRatings.ContainsKey(analystRating.Symbol))
|
||||
{
|
||||
analystRatings.Add(analystRating.Symbol,new AnalystRatings());
|
||||
}
|
||||
analystRatings[analystRating.Symbol].Add(analystRating);
|
||||
}
|
||||
return analystRatings;
|
||||
}
|
||||
catch (Exception exception)
|
||||
{
|
||||
MDTrace.WriteLine(LogLevel.DEBUG,exception);
|
||||
return null;
|
||||
}
|
||||
finally
|
||||
{
|
||||
if(null!=sqlCommand)sqlCommand.Dispose();
|
||||
if (null != sqlDataReader) {sqlDataReader.Close();sqlDataReader.Dispose();}
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
public static AnalystRatings GetAnalystRatingsMaxDate(String symbol,DateTime maxDate)
|
||||
{
|
||||
MySqlConnection sqlConnection = null;
|
||||
@@ -252,6 +311,7 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
public static AnalystRatings GetAnalystRatings(String symbol, DateTime date)
|
||||
{
|
||||
MySqlConnection sqlConnection = null;
|
||||
@@ -307,6 +367,7 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
public static AnalystRatings GetAnalystRatings(DateTime date)
|
||||
{
|
||||
MySqlConnection sqlConnection = null;
|
||||
@@ -360,6 +421,7 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
public static AnalystRatings GetAnalystRatings(String symbol)
|
||||
{
|
||||
MySqlConnection sqlConnection = null;
|
||||
@@ -414,7 +476,7 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
// ****************************************************************************************************************************************************
|
||||
|
||||
public static List<String> GetAnalystRatingsDates()
|
||||
{
|
||||
MySqlConnection sqlConnection = null;
|
||||
@@ -451,6 +513,7 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
public static bool InsertAnalystRatings(AnalystRatings analystRatings)
|
||||
{
|
||||
MySqlConnection sqlConnection = null;
|
||||
@@ -500,6 +563,7 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
public static bool ContainsAnalystRating(AnalystRating analystRating)
|
||||
{
|
||||
MySqlConnection sqlConnection = null;
|
||||
@@ -536,6 +600,7 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
private static bool DeleteAnalystRatings(AnalystRatings analystRatings, MySqlConnection sqlConnection, MySqlTransaction sqlTransaction)
|
||||
{
|
||||
try
|
||||
|
||||
@@ -94,10 +94,10 @@ namespace MarketData.DataAccess
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Updates the beta36 and bet6 for a symbol for a specific date
|
||||
/// Updates the beta36, beta24, and bet06 for a symbol for a specific date
|
||||
/// </summary>
|
||||
/// <returns></returns>
|
||||
public static bool UpdateBeta(String symbol,DateTime asof,double beta36, double beta06)
|
||||
public static bool UpdateBeta(String symbol,DateTime asof,double beta36, double beta24, double beta06)
|
||||
{
|
||||
MySqlConnection sqlConnection = null;
|
||||
MySqlTransaction sqlTransaction = null;
|
||||
@@ -112,12 +112,20 @@ namespace MarketData.DataAccess
|
||||
sqlConnection = SqlUtils.CreateMySqlConnection(MainDataSource.Instance.LocateDataSource("market_data"));
|
||||
sqlTransaction = sqlConnection.BeginTransaction(System.Data.IsolationLevel.ReadCommitted);
|
||||
sb.Append("update fundamentals set ");
|
||||
|
||||
sb.Append("beta_calc_36=");
|
||||
if (!Double.IsNaN(beta36)) sb.Append(beta36).Append(",");
|
||||
else sb.Append("null").Append(",");
|
||||
|
||||
sb.Append("beta_calc_24=");
|
||||
if (!Double.IsNaN(beta24)) sb.Append(beta24).Append(",");
|
||||
else sb.Append("null").Append(",");
|
||||
|
||||
|
||||
sb.Append("beta_calc_06=");
|
||||
if (!Double.IsNaN(beta06)) sb.Append(beta06);
|
||||
else sb.Append("null");
|
||||
|
||||
sb.Append(" where ");
|
||||
sb.Append("symbol='").Append(symbol).Append("' and asof =").Append(SqlUtils.ToSqlDate(asof,true));
|
||||
strQuery = sb.ToString();
|
||||
@@ -332,7 +340,7 @@ namespace MarketData.DataAccess
|
||||
{
|
||||
StringBuilder sb = new StringBuilder();
|
||||
sqlConnection = SqlUtils.CreateMySqlConnection(MainDataSource.Instance.LocateDataSource("market_data"));
|
||||
sb.Append("select symbol,asof,next_earnings_date,beta,low52,high52,volume,market_cap,pe,eps,peg,return_on_assets,return_on_equity,total_cash,total_debt,shares_outstanding,revenue,revenue_per_share,qtrly_revenue_growth,gross_profit,ebitda,net_income_available_to_common,book_value_per_share,operating_cashflow,leveraged_free_cashflow,book_value_per_share*shares_outstanding as equity,trailing_pe,ebit,enterprise_value,source,beta_calc_36,beta_calc_06 from fundamentals where symbol=");
|
||||
sb.Append("select symbol,asof,next_earnings_date,beta,low52,high52,volume,market_cap,pe,eps,peg,return_on_assets,return_on_equity,total_cash,total_debt,shares_outstanding,revenue,revenue_per_share,qtrly_revenue_growth,gross_profit,ebitda,net_income_available_to_common,book_value_per_share,operating_cashflow,leveraged_free_cashflow,book_value_per_share*shares_outstanding as equity,trailing_pe,ebit,enterprise_value,source,beta_calc_36,beta_calc_06,beta_calc_24 from fundamentals where symbol=");
|
||||
sb.Append("'").Append(symbol).Append("'").Append(" ");
|
||||
sb.Append("and asof=(select max(asof) from fundamentals where symbol='").Append(symbol).Append("')");
|
||||
strQuery = sb.ToString(); ;
|
||||
@@ -373,6 +381,7 @@ namespace MarketData.DataAccess
|
||||
if (!sqlDataReader.IsDBNull(29)) fundamental.Source = sqlDataReader.GetString(29);
|
||||
if (!sqlDataReader.IsDBNull(30)) fundamental.BetaCalc36 = sqlDataReader.GetDouble(30);
|
||||
if (!sqlDataReader.IsDBNull(31)) fundamental.BetaCalc06 = sqlDataReader.GetDouble(31);
|
||||
if (!sqlDataReader.IsDBNull(32)) fundamental.BetaCalc24 = sqlDataReader.GetDouble(32);
|
||||
BalanceSheet balanceSheet=BalanceSheetDA.GetBalanceSheetOnOrBefore(symbol,fundamental.AsOf,BalanceSheet.PeriodType.Annual);
|
||||
if(null!=balanceSheet&&!double.IsNaN(balanceSheet.TotalStockHolderEquity)&&!double.IsNaN(fundamental.TotalDebt)&&0!=fundamental.TotalDebt)fundamental.DebtToEquity=fundamental.TotalDebt/balanceSheet.TotalStockHolderEquity;
|
||||
return fundamental;
|
||||
@@ -400,7 +409,7 @@ namespace MarketData.DataAccess
|
||||
{
|
||||
StringBuilder sb = new StringBuilder();
|
||||
sqlConnection = SqlUtils.CreateMySqlConnection(MainDataSource.Instance.LocateDataSource("market_data"));
|
||||
sb.Append("select symbol,asof,next_earnings_date,beta,low52,high52,volume,market_cap,pe,eps,peg,return_on_assets,return_on_equity,total_cash,total_debt,shares_outstanding,revenue,revenue_per_share,qtrly_revenue_growth,gross_profit,ebitda,net_income_available_to_common,book_value_per_share,operating_cashflow,leveraged_free_cashflow,book_value_per_share*shares_outstanding as equity,trailing_pe,ebit,enterprise_value,source,beta_calc_36,beta_calc_06 from fundamentals where symbol=");
|
||||
sb.Append("select symbol,asof,next_earnings_date,beta,low52,high52,volume,market_cap,pe,eps,peg,return_on_assets,return_on_equity,total_cash,total_debt,shares_outstanding,revenue,revenue_per_share,qtrly_revenue_growth,gross_profit,ebitda,net_income_available_to_common,book_value_per_share,operating_cashflow,leveraged_free_cashflow,book_value_per_share*shares_outstanding as equity,trailing_pe,ebit,enterprise_value,source,beta_calc_36,beta_calc_06,beta_calc_24 from fundamentals where symbol=");
|
||||
sb.Append("'").Append(symbol).Append("'").Append(" ");
|
||||
sb.Append("and asof=").Append("'").Append(Utility.DateTimeToStringYYYYHMMHDD(asof)).Append("'").Append(";");
|
||||
strQuery = sb.ToString(); ;
|
||||
@@ -441,7 +450,8 @@ namespace MarketData.DataAccess
|
||||
if (!sqlDataReader.IsDBNull(28)) fundamental.EnterpriseValue = sqlDataReader.GetDouble(28);
|
||||
if (!sqlDataReader.IsDBNull(29)) fundamental.Source = sqlDataReader.GetString(29);
|
||||
if (!sqlDataReader.IsDBNull(30)) fundamental.BetaCalc36 = sqlDataReader.GetDouble(30);
|
||||
if (!sqlDataReader.IsDBNull(3)) fundamental.BetaCalc06 = sqlDataReader.GetDouble(31);
|
||||
if (!sqlDataReader.IsDBNull(31)) fundamental.BetaCalc06 = sqlDataReader.GetDouble(31);
|
||||
if (!sqlDataReader.IsDBNull(32)) fundamental.BetaCalc24 = sqlDataReader.GetDouble(32);
|
||||
if (null != balanceSheet && !double.IsNaN(balanceSheet.TotalStockHolderEquity) && !double.IsNaN(fundamental.TotalDebt) && 0 != fundamental.TotalDebt)
|
||||
{
|
||||
fundamental.DebtToEquity=fundamental.TotalDebt/balanceSheet.TotalStockHolderEquity;
|
||||
@@ -520,7 +530,7 @@ namespace MarketData.DataAccess
|
||||
{
|
||||
StringBuilder sb = new StringBuilder();
|
||||
sqlConnection = SqlUtils.CreateMySqlConnection(MainDataSource.Instance.LocateDataSource("market_data"));
|
||||
sb.Append("SELECT A.asof,A.symbol, A.market_cap,A.ebitda,A.pe,A.revenue_per_share,A.beta,A.beta_calc_36,A.beta_calc_06 FROM fundamentals A JOIN ");
|
||||
sb.Append("SELECT A.asof,A.symbol, A.market_cap,A.ebitda,A.pe,A.revenue_per_share,A.beta,A.beta_calc_36,A.beta_calc_06,A.beta_calc_24 FROM fundamentals A JOIN ");
|
||||
sb.Append("(SELECT MAX(asof) asof,symbol FROM fundamentals WHERE asof<=").Append("'");
|
||||
sb.Append(Utility.DateTimeToStringYYYYHMMHDD(tradeDate.Date));
|
||||
sb.Append("'");
|
||||
@@ -542,6 +552,7 @@ namespace MarketData.DataAccess
|
||||
if(!sqlDataReader.IsDBNull(6)) fundamental.Beta = sqlDataReader.GetDouble(6);
|
||||
if(!sqlDataReader.IsDBNull(7)) fundamental.BetaCalc36 = sqlDataReader.GetDouble(7);
|
||||
if(!sqlDataReader.IsDBNull(8)) fundamental.BetaCalc06 = sqlDataReader.GetDouble(8);
|
||||
if(!sqlDataReader.IsDBNull(9)) fundamental.BetaCalc24 = sqlDataReader.GetDouble(9);
|
||||
if(!fundamentals.ContainsKey(fundamental.Symbol))fundamentals.Add(fundamental.Symbol,fundamental);
|
||||
}
|
||||
return fundamentals;
|
||||
@@ -572,7 +583,7 @@ namespace MarketData.DataAccess
|
||||
if(null==maxDate)return null;
|
||||
StringBuilder sb = new StringBuilder();
|
||||
sqlConnection = SqlUtils.CreateMySqlConnection(MainDataSource.Instance.LocateDataSource("market_data"));
|
||||
sb.Append("select symbol,asof,next_earnings_date,beta,low52,high52,volume,market_cap,pe,eps,peg,return_on_assets,return_on_equity,total_cash,total_debt,shares_outstanding,revenue,revenue_per_share,qtrly_revenue_growth,gross_profit,ebitda,net_income_available_to_common,book_value_per_share,operating_cashflow,leveraged_free_cashflow,book_value_per_share*shares_outstanding as equity,trailing_pe,ebit,enterprise_value,source,beta_calc_36,beta_calc_06 from fundamentals where symbol=");
|
||||
sb.Append("select symbol,asof,next_earnings_date,beta,low52,high52,volume,market_cap,pe,eps,peg,return_on_assets,return_on_equity,total_cash,total_debt,shares_outstanding,revenue,revenue_per_share,qtrly_revenue_growth,gross_profit,ebitda,net_income_available_to_common,book_value_per_share,operating_cashflow,leveraged_free_cashflow,book_value_per_share*shares_outstanding as equity,trailing_pe,ebit,enterprise_value,source,beta_calc_36,beta_calc_06,beta_calc_24 from fundamentals where symbol=");
|
||||
sb.Append("'").Append(symbol).Append("'").Append(" ");
|
||||
sb.Append("and asof=").Append("'").Append(Utility.DateTimeToStringYYYYHMMHDD(maxDate.Value)).Append("'");
|
||||
sb.Append(" limit 1");
|
||||
@@ -615,6 +626,7 @@ namespace MarketData.DataAccess
|
||||
if (!sqlDataReader.IsDBNull(29)) fundamental.Source = sqlDataReader.GetString(29);
|
||||
if (!sqlDataReader.IsDBNull(30)) fundamental.BetaCalc36 = sqlDataReader.GetDouble(30);
|
||||
if (!sqlDataReader.IsDBNull(31)) fundamental.BetaCalc06 = sqlDataReader.GetDouble(31);
|
||||
if (!sqlDataReader.IsDBNull(32)) fundamental.BetaCalc24 = sqlDataReader.GetDouble(32);
|
||||
if (!double.IsNaN(totalStockHolderEquity) && !double.IsNaN(fundamental.TotalDebt))
|
||||
{
|
||||
if(0.00==totalStockHolderEquity)fundamental.TotalDebt=0.00;
|
||||
@@ -650,7 +662,7 @@ namespace MarketData.DataAccess
|
||||
{
|
||||
Fundamental fundamental = fundamentals[index];
|
||||
StringBuilder sb = new StringBuilder();
|
||||
sb.Append("insert into fundamentals (symbol,asof,next_earnings_date,beta,beta_calc_36,beta_calc_06,low52,high52,volume,market_cap,pe,eps,peg,return_on_assets,return_on_equity,total_cash,total_debt,shares_outstanding,revenue,revenue_per_share,qtrly_revenue_growth,gross_profit,ebitda,net_income_available_to_common,book_value_per_share,operating_cashflow,leveraged_free_cashflow,trailing_pe,ebit,enterprise_value,source) ");
|
||||
sb.Append("insert into fundamentals (symbol,asof,next_earnings_date,beta,beta_calc_36,beta_calc_24,beta_calc_06,low52,high52,volume,market_cap,pe,eps,peg,return_on_assets,return_on_equity,total_cash,total_debt,shares_outstanding,revenue,revenue_per_share,qtrly_revenue_growth,gross_profit,ebitda,net_income_available_to_common,book_value_per_share,operating_cashflow,leveraged_free_cashflow,trailing_pe,ebit,enterprise_value,source) ");
|
||||
sb.Append("values(");
|
||||
sb.Append("'").Append(fundamental.Symbol).Append("'").Append(",");
|
||||
sb.Append("'").Append(Utility.DateTimeToStringYYYYHMMHDD(fundamental.AsOf)).Append("'").Append(",");
|
||||
@@ -660,6 +672,8 @@ namespace MarketData.DataAccess
|
||||
else sb.Append("null").Append(",");
|
||||
if (!Double.IsNaN(fundamental.BetaCalc36)) sb.Append(fundamental.BetaCalc36).Append(",");
|
||||
else sb.Append("null").Append(",");
|
||||
if (!Double.IsNaN(fundamental.BetaCalc24)) sb.Append(fundamental.BetaCalc24).Append(",");
|
||||
else sb.Append("null").Append(",");
|
||||
if (!Double.IsNaN(fundamental.BetaCalc06)) sb.Append(fundamental.BetaCalc06).Append(",");
|
||||
else sb.Append("null").Append(",");
|
||||
if (!Double.IsNaN(fundamental.Low52)) sb.Append(fundamental.Low52).Append(",");
|
||||
@@ -746,7 +760,7 @@ namespace MarketData.DataAccess
|
||||
sqlTransaction = sqlConnection.BeginTransaction(System.Data.IsolationLevel.ReadCommitted);
|
||||
DeleteFundamental(fundamental, sqlConnection, sqlTransaction);
|
||||
StringBuilder sb = new StringBuilder();
|
||||
sb.Append("insert into fundamentals (symbol,asof,next_earnings_date,beta,beta_calc_36,beta_calc_06,low52,high52,volume,market_cap,pe,eps,peg,return_on_assets,return_on_equity,total_cash,total_debt,shares_outstanding,revenue,revenue_per_share,qtrly_revenue_growth,gross_profit,ebitda,net_income_available_to_common,book_value_per_share,operating_cashflow,leveraged_free_cashflow,trailing_pe,ebit,enterprise_value,source) ");
|
||||
sb.Append("insert into fundamentals (symbol,asof,next_earnings_date,beta,beta_calc_36,beta_calc_24,beta_calc_06,low52,high52,volume,market_cap,pe,eps,peg,return_on_assets,return_on_equity,total_cash,total_debt,shares_outstanding,revenue,revenue_per_share,qtrly_revenue_growth,gross_profit,ebitda,net_income_available_to_common,book_value_per_share,operating_cashflow,leveraged_free_cashflow,trailing_pe,ebit,enterprise_value,source) ");
|
||||
sb.Append("values(");
|
||||
sb.Append("'").Append(fundamental.Symbol).Append("'").Append(",");
|
||||
sb.Append("'").Append(Utility.DateTimeToStringYYYYHMMHDD(fundamental.AsOf)).Append("'").Append(",");
|
||||
@@ -756,6 +770,8 @@ namespace MarketData.DataAccess
|
||||
else sb.Append("null").Append(",");
|
||||
if (!Double.IsNaN(fundamental.BetaCalc36)) sb.Append(fundamental.BetaCalc36).Append(",");
|
||||
else sb.Append("null").Append(",");
|
||||
if (!Double.IsNaN(fundamental.BetaCalc24)) sb.Append(fundamental.BetaCalc24).Append(",");
|
||||
else sb.Append("null").Append(",");
|
||||
if (!Double.IsNaN(fundamental.BetaCalc06)) sb.Append(fundamental.BetaCalc06).Append(",");
|
||||
else sb.Append("null").Append(",");
|
||||
if (!Double.IsNaN(fundamental.Low52)) sb.Append(fundamental.Low52).Append(",");
|
||||
|
||||
@@ -12,6 +12,58 @@ namespace MarketData.DataAccess
|
||||
private ZacksRankDA()
|
||||
{
|
||||
}
|
||||
|
||||
// Get the latest rank for symbol that falls on or before the specified date
|
||||
public static Dictionary<String,ZacksRank> GetZacksRankOnOrBefore(List<String> symbols, DateTime maxDate)
|
||||
{
|
||||
MySqlConnection sqlConnection = null;
|
||||
MySqlDataReader sqlDataReader = null;
|
||||
MySqlCommand sqlCommand=null;
|
||||
String strQuery = null;
|
||||
Dictionary<String,ZacksRank> zacksRanks = new Dictionary<String,ZacksRank>();
|
||||
|
||||
try
|
||||
{
|
||||
|
||||
StringBuilder sb = new StringBuilder();
|
||||
sqlConnection = SqlUtils.CreateMySqlConnection(MainDataSource.Instance.LocateDataSource("market_data"));
|
||||
sb.Append("SELECT B.symbol, B.zacks_rank, B.date, B.type ");
|
||||
sb.Append("FROM (SELECT symbol,zacks_rank,date,type , ROW_NUMBER() OVER ");
|
||||
sb.Append("(PARTITION BY symbol ORDER BY date desc) AS rownum ");
|
||||
sb.Append("FROM zacksrank WHERE symbol IN ").Append(SqlUtils.CreateInClause(symbols)).Append(" and DATE<=").Append(SqlUtils.ToSqlDate(maxDate,true)).Append(")B ");
|
||||
sb.Append("WHERE B.rownum<=1");
|
||||
strQuery = sb.ToString(); ;
|
||||
sqlCommand = new MySqlCommand(strQuery, sqlConnection);
|
||||
sqlCommand.CommandTimeout = SqlUtils.COMMAND_TIMEOUT;
|
||||
sqlDataReader = sqlCommand.ExecuteReader();
|
||||
|
||||
while(sqlDataReader.Read())
|
||||
{
|
||||
ZacksRank zacksRank=new ZacksRank();
|
||||
zacksRank.Symbol=sqlDataReader.GetString(0);
|
||||
zacksRank.Rank=sqlDataReader.GetString(1);
|
||||
zacksRank.Date=sqlDataReader.GetDateTime(2);
|
||||
if(!sqlDataReader.IsDBNull(3))zacksRank.Type=sqlDataReader.GetString(3);
|
||||
if(!zacksRanks.ContainsKey(zacksRank.Symbol))
|
||||
{
|
||||
zacksRanks.Add(zacksRank.Symbol, zacksRank);
|
||||
}
|
||||
}
|
||||
return zacksRanks;
|
||||
}
|
||||
catch (Exception exception)
|
||||
{
|
||||
MDTrace.WriteLine(LogLevel.DEBUG,exception);
|
||||
return null;
|
||||
}
|
||||
finally
|
||||
{
|
||||
if(null!=sqlCommand)sqlCommand.Dispose();
|
||||
if (null != sqlDataReader) {sqlDataReader.Close();sqlDataReader.Dispose();}
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
// Get the latest rank for symbol that falls on or before the specified date
|
||||
public static ZacksRank GetZacksRankOnOrBefore(String symbol, DateTime date)
|
||||
{
|
||||
@@ -54,6 +106,7 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
// Get the most recent rank date on or before the given date for specified symbol
|
||||
private static DateTime? GetMaxDateOnOrBefore(String symbol, DateTime date)
|
||||
{
|
||||
@@ -92,6 +145,7 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
// Get the latest rank for symbol
|
||||
public static ZacksRank GetZacksRank(String symbol)
|
||||
{
|
||||
@@ -131,6 +185,7 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
// Insert a rank if the latest rank that we have is different from the one to be added or we do not have a rank
|
||||
public static bool InsertZacksRank(ZacksRank zacksRank)
|
||||
{
|
||||
@@ -179,6 +234,7 @@ namespace MarketData.DataAccess
|
||||
if (null != sqlConnection) sqlConnection.Close();
|
||||
}
|
||||
}
|
||||
|
||||
private static String GetChangeType(ZacksRank latestRank,ZacksRank newRank)
|
||||
{
|
||||
if(null==latestRank)return "Initial";
|
||||
@@ -190,6 +246,7 @@ namespace MarketData.DataAccess
|
||||
return "NoChange";
|
||||
|
||||
}
|
||||
|
||||
// Delete a ranking on symbol and date
|
||||
private static bool DeleteZacksRank(ZacksRank zacksRank,MySqlConnection sqlConnection,MySqlTransaction sqlTransaction)
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user