提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:鲍佳佳|2020-07-03 17:43:18.270|阅读 443 次
概述:本文介绍如何对日历控件使用自定义数据源。它是基于标准的Visual Basic CalendarSample应用程序中包含的MySQL数据库提供程序示例进行描述的。
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
日历控件具有对以下数据提供程序的内置支持:内存,XML文件(或二进制文件),数据库(访问),MAPI(Outlook)。
但是,许多人已经有自己的数据来源,可以在“日历”窗口中显示数据。这可能是不支持Codejock Calendar数据库模型的旧数据库,可能是特定的数据库服务器(Microsoft SQL Server,MySQL,FoxPro等),甚至可能是指定数据对象的自定义内存数组,而该数组已经具有自己的加载/保存代码。
另一个问题是如何允许多人在不同的工作站上同时处理同一组约会(请注意,使用所描述的解决方案可能只会部分解决此问题)。
第三个问题是当人们拥有大量约定数据并且怀疑所有数据同时保存在内存中时可能会出现问题。
通过实施自定义日历数据提供程序,可以解决所有这些问题。
简单的解决方案-自定义加载/保存事件代码
首先让我们考虑一个最简单的情况-您有一个旧数据库,只想在单个工作站上使用它,并且想用相应的工具栏按钮打开并保存所有更改(或其他方式,主要思想是数据库并不总是与日历上显示的数据库同步)。
在这种情况下,正确的解决方案是根本不使用自定义数据提供程序:
您所需要做的就是使用标准的内存数据提供程序,该程序默认情况下是通过Calendar控件创建的。当然,它可以序列化为XML文件,但是如果您不提供文件名,那么Memory DataProvider将会成为您的事件的简单存储。您必须用事件填充日历,然后允许用户使用它们,并在保存时通过迭代所有日历事件来更新数据库中的所有数据。这可能以以下方式显示:
加载:'加载事件 Sub Populate() objCalendar.DataProvider.RemoveAllEvents '<打开事件记录集或集合> '<迭代此集合> 对于 objEventsCollection 中的每个 objEvent 设置 objCalendarEvent = objCalendar.DataProvider.CreateEventEx(objEvent.ID) objCalendarEvent.StartTime = .. 。 ... objCalendar.DataProvider.AddEvent objCalendarEvent 下一页 objCalendar.Populate 结束小组保存:
“迭代事件和保存到数据库 私人 小组保存() 昏暗 objEvent 作为 CalendarEvent 对于 每个 objEvent 在 objCalendar.DataProvider.GetAllEventsRaw ” <节省事件属性> “objEvent.Id ‘objEvent.Subject 接着 ’<提交节省> 结束 子复杂的解决方案-定制数据提供者
CalendarControl.SetDataProvider“ Provider =自定义;”当您拥有自己要显示的数据源(例如DB或内存集合),约定记录众多或想要具有多用户工作环境时,需要自定义数据提供程序。
已经有几个标准示例可用(用于MS SQL Server和MySQL)。
简要介绍其工作原理:它要求您在数据源中创建/读取/更新日历事件。设置“自定义数据提供程序-日历”时,您可以发送一些通知,以捕获和处理数据操作:例如从数据库读取事件数据并填充日历事件对象成员或更新/创建/删除数据库记录。Private Sub Calendar_DoCreateEvent(ByVal pEvent As _ XtremeCalendarControl.CalendarEvent,NewEventID _ As Long,bResult As Boolean) '1)从pEvent获取属性'2)准备并执行相应的SQL语句,该语句将'新事件添加到数据库中'3)如果数据库有自动递增的事件ID字段,检索“它一个新的事件,并分配到NewEventID ” 4)集bResult为true,如果一切操作顺利完 结束小组关于递归
加载重复模式时,还必须加载和设置与此模式相关的所有日历事件异常。
正在加载重复发生master事件
当您读取具有“master”重复状态的日历事件对象并将其返回给自定义数据提供程序时,有一个技巧。
日历事件对象有2个特殊的自定义属性:“ process_RecurrenceState”和“ process_RecurrencePatternID”。它们用于处理master事件。如果设置了它们,并且RecurrenceState为“ master”,则自定义数据提供程序将触发DoReadRPattern事件,并将该事件作为Master。并且还将为RetrieveDayEvents方法生成事件。这些属性是临时的,它们将被数据提供者删除。
如果未设置这些属性–但是自定义数据提供者期望主事件已经完成-调用CreateRecurrence方法并设置重复模式。
当事件和模式分别存储在不同的表中时,此机制对于DB数据提供程序很有用。
但是,如果事件存储在某个内存集合或数组中,则不应使用它,因为主事件在内部存储了重复模式。
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@cahobeh.cn
本文探讨 SQL Server 中 NULL 和空值之间的区别,并讨论如何有效地处理它们。
Unity 是一款功能极其丰富的游戏引擎,允许开发人员将各种媒体集成到他们的项目中。但是,它缺少最令人兴奋的功能之一 - 将 Web 内容(例如 HTML、CSS 和 JavaScript)直接渲染到 3D 场景中的纹理上的能力。在本文中,我们将介绍如何使用 DotNetBrowser 在 Unity3D 中将 Web 内容渲染为纹理。
DevExpress v24.2帮助文档正式发布上线了,请按版本按需下载~
本教程将向您展示如何用MyEclipse构建一个Web项目,欢迎下载最新版IDE体验!
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@cahobeh.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢