当前位置: 首页>>代码示例>>C#>>正文


C# IDataContext.Messages方法代码示例

本文整理汇总了C#中IDataContext.Messages方法的典型用法代码示例。如果您正苦于以下问题:C# IDataContext.Messages方法的具体用法?C# IDataContext.Messages怎么用?C# IDataContext.Messages使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在IDataContext的用法示例。


在下文中一共展示了IDataContext.Messages方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: UpdateTopicInfoByFilter

		/// <summary>
		/// Обновляет агрегатные данные по темам (таблицу topic_info).
		/// Эта процедура сначала удаляет записи соответствующие параметру filter,
		/// а потом формирует агрегатные данные и добавляет их в topic_info.
		/// Транзакция должна контролироваться вызывающим методом.
		/// </summary>
		/// <param name="db"></param>
		/// <param name="msgPredicate">Необязательный параметр позволяющий задать
		/// фильтрацию тем данные по которым нужно пересчитать. 
		/// Может быть null или string.Empty. Если параметр не задан, 
		/// обновляются все сообщения. При этом время обновления может быть
		/// довольно большим (на Athlon 2100+ 512 MB RAM ~ 1 мин.).
		/// Пример: "mid IN (1, 2, 3)" обновит агрегатные значения
		/// для тем 1, 2 и 3.</param>
		/// <param name="topicPredicate">комплиментарный <see cref="msgPredicate"/> предикат для TopicInfo</param>
		/// <returns>Возвращает количество вставленных записей.</returns>
		private static int UpdateTopicInfoByFilter(
			IDataContext db,
			[CanBeNull] Expression<Func<ITopicInfo, bool>> topicPredicate,
			[CanBeNull] Expression<Func<IForumMessage, bool>> msgPredicate)
		{
			// Удаляем.
			//
			if (topicPredicate != null)
				db
					.TopicInfos(topicPredicate)
					.Delete();
			else
				db.TopicInfos().Delete();

			var rates = db.Rates();
			var mods = db.Moderatorials();

			var msgs = db.Messages(m => m.TopicID == 0);
			if (msgPredicate != null)
				msgs = msgs.Where(msgPredicate);

			var updated =
				msgs
					.Into(db.TopicInfos())
						.Value(_ => _.MessageID, m => m.ID)
						.Value(_ => _.ForumID, m => m.ForumID)
					// ReSharper disable once UseCollectionCountProperty
						.Value(_ => _.AnswersCount, m => m.TopicAnswers.Count())
						.Value(
							_ => _.AnswersRates,
							m =>
								rates
									.Where(r => r.Message.TopicID == m.ID && r.RateType > 0)
									.Sum(r => (int)r.RateType * r.Multiplier))
						.Value(
							_ => _.AnswersUnread,
							m => m.TopicAnswers.Count(im => !im.IsRead) + (m.IsRead ? 0 : 1))
						.Value(
							_ => _.AnswersSmiles,
							m =>
								rates
									.Count(r => r.Message.TopicID == m.ID && r.RateType == MessageRates.Smile))
						.Value(
							_ => _.AnswersAgrees,
							m =>
								rates
									.Count(r => r.Message.TopicID == m.ID && r.RateType == MessageRates.Agree))
						.Value(
							_ => _.AnswersDisagrees,
							m =>
								rates
									.Count(r => r.Message.TopicID == m.ID && r.RateType == MessageRates.DisAgree))
						.Value(
							_ => _.AnswersToMeUnread,
							m =>
								m
									.TopicAnswers
									.Count(im => !im.IsRead && im.Parent.UserID == Config.Instance.SelfId))
						.Value(_ => _.AnswersMarked, m => m.TopicAnswers.Count(im => im.IsMarked))
						.Value(_ => _.LastUpdateDate, m => m.TopicAnswers.Max(im => (DateTime?)im.Date) ?? m.Date)
						.Value(
							_ => _.AnswersModeratorials,
							m =>
								mods
									.Count(
										mod =>
											mod.Message.TopicID == m.ID
											&& (mod.Message.LastModerated == null || mod.Create > mod.Message.LastModerated)))
						.Value(_ => _.SelfRates, m => m.Rating())
						.Value(_ => _.SelfSmiles, m => m.SmileCount())
						.Value(_ => _.SelfAgrees, m => m.AgreeCount())
						.Value(_ => _.SelfDisagrees, m => m.DisagreeCount())
						.Value(_ => _.SelfModeratorials, m => m.ActiveModeratorialCount())
					.Insert();

			return updated;
		}
开发者ID:rsdn,项目名称:janus,代码行数:93,代码来源:DatabaseManager.Aggregates.cs

示例2: AddMessages

		/// <summary>
		/// Добавление сообшений полученыых с сервера в базу
		/// </summary>
		/// <param name="provider"></param>
		/// <param name="db"></param>
		/// <param name="messages">Добавляемые сообщения</param>
		/// <param name="selfid"></param>
		/// <param name="progressHandler">обработчик прогресса обработки сообщений</param>
		/// <param name="updatedTopicIds">Какие топики были обновлены.</param>
		/// <param name="updatedMessageIds">Какие сообщения были добавлены.</param>
		private static void AddMessages(
			[JetBrains.Annotations.NotNull] IServiceProvider provider,
			IDataContext db,
			JanusMessageInfo[] messages,
			int selfid,
			Action<int, int> progressHandler,
			out int[] updatedTopicIds,
			out int[] updatedMessageIds)
		{
			if (db == null)
				throw new ArgumentNullException(nameof(db));
			if (messages == null)
				throw new ArgumentNullException(nameof(messages));

			var msgIds = new List<int>();
			var topicIds = new List<int>();
			var processed = 0;
			foreach (var msg in messages)
			{
				if (ForumsSubscriptionHelper.IsTrashForum(msg.forumId))
					try
					{
						var mid = msg.messageId;
						db.TopicInfos(ti => ti.MessageID == mid).Delete();
						db.Messages(m => m.ID == mid).Delete();
					}
					catch (Exception)
					{
						provider.LogError(Resources.ErrorOnMessageDelete + msg.messageId);
					}
				else
				{
					var updatedTid = db.Message(msg.messageId, m => (int?) m.TopicID);

					if (msg.message.IsNullOrEmpty())
						msg.message = "<none>";

					var lastModerated =
						msg.lastModerated == DateTime.MinValue
							? null
							: (DateTime?) msg.lastModerated;
					try
					{
						if (!updatedTid.HasValue)
						{
							var markRead = false;
							if (msg.parentId != 0)
								markRead = db.Message(msg.parentId, m => m.ReadReplies);

							var isRead =
								msg.userId == selfid
									? provider.GetRequiredService<IRsdnSyncConfigService>().GetConfig().MarkOwnMessages
									: markRead;

							db
								.Messages()
								.Value(_ => _.ID, msg.messageId)
								.Value(_ => _.ForumID, msg.forumId)
								.Value(_ => _.TopicID, msg.topicId)
								.Value(_ => _.ParentID, msg.parentId)
								.Value(_ => _.Date, msg.messageDate)
								.Value(_ => _.UserNick, msg.userNick)
								.Value(_ => _.Subject, msg.subject)
								.Value(_ => _.Message, msg.message)
								.Value(_ => _.UserClass, ToJanusUserClass(msg.userRole))
								.Value(_ => _.IsRead, isRead)
								.Value(_ => _.UserID, msg.userId)
								.Value(_ => _.ArticleId, msg.articleId)
								.Value(_ => _.ReadReplies, markRead)
								.Value(_ => _.Name, msg.messageName)
								.Value(_ => _.LastModerated, lastModerated)
								.Value(_ => _.Closed, msg.closed)
								.Insert();

							msgIds.Add(msg.messageId);
						}
						else
						{
							var locMsg = msg;
							db
								.Messages(m => m.ID == locMsg.messageId)
								.Set(_ => _.ForumID, msg.forumId)
								.Set(_ => _.TopicID, msg.topicId)
								.Set(_ => _.ParentID, msg.parentId)
								.Set(_ => _.Date, msg.messageDate)
								.Set(_ => _.UserID, msg.userId)
								.Set(_ => _.UserNick, msg.userNick)
								.Set(_ => _.Subject, msg.subject)
								.Set(_ => _.Message, msg.message)
								.Set(_ => _.UserClass, ToJanusUserClass(msg.userRole))
//.........这里部分代码省略.........
开发者ID:rsdn,项目名称:janus,代码行数:101,代码来源:MessagesSyncHelper.cs

示例3: UpdateTopicInfoSpecified

		public static void UpdateTopicInfoSpecified(
			IServiceProvider provider,
			IDataContext db,
			IEnumerable<int> affectedIds)
		{
			foreach (var portion in affectedIds.SplitForInClause(provider))
			{
				var locPortion = portion;

				db
					.TopicInfos(ti => locPortion.Contains(ti.MessageID))
						.Set(_ => _.AnswersUnread,     0)
						.Set(_ => _.AnswersToMeUnread, 0)
					.Update();

				var msgs = db.Messages();
				var affectedTids =
					msgs
						.Where(m => locPortion.Contains(m.ID))
						.Select(m => m.TopicID == 0 ? m.ID : m.TopicID)
						.Distinct();

				var readCounts =
					affectedTids
						.Select(
							tid =>
								new
								{
									TopicID = tid,
									UnreadCount =
										msgs.Count(m => !m.IsRead && m.TopicID == tid),
									MeUnreadCount =
										msgs.Count(m => !m.IsRead && m.UserID == Config.Instance.SelfId && m.TopicID == tid)
								})
						.ToList();

				foreach (var cnt in readCounts)
				{
					var locCnt = cnt;
					db
						.TopicInfos(ti => ti.MessageID == locCnt.TopicID)
							.Set(_ => _.AnswersUnread,     locCnt.UnreadCount)
							.Set(_ => _.AnswersToMeUnread, locCnt.MeUnreadCount)
						.Update();
				}
			}
		}
开发者ID:rsdn,项目名称:janus,代码行数:47,代码来源:DatabaseManager.Aggregates.cs

示例4: ClearMarkers

        /// <summary>
        /// Удаляет маркеры.
        /// </summary>
        /// <param name="db">См. <see cref="DbManager"/></param>
        /// <param name="maxMsgId">Максимальный ID сообщения, 
        /// который учавствует в выборке.</param>
        private static void ClearMarkers(IDataContext db, int maxMsgId)
        {
            // Транзакцией занимается вызывающий код.
            db
                .Messages(m => m.IsMarked && m.ID <= maxMsgId)
                    .Set(_ => _.IsMarked, false)
                .Update();

            db
                .TopicInfos(ti => ti.AnswersMarked > 0 && ti.MessageID <= maxMsgId)
                    .Set(_ => _.AnswersMarked, 0)
                .Update();
        }
开发者ID:permyakov,项目名称:janus,代码行数:19,代码来源:StateObject.cs


注:本文中的IDataContext.Messages方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。