- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想知道如何使用 CaSTLe AR 来“播种”自动递增的主键值?例如,希望 Orders 表的主键从 10000 开始。这是 1. 可能的 2. 创建订单号的好解决方案吗?
也许有一种方法可以在不是 pk 的 DB 上连续自动递增字段,播种到 10000?
最佳答案
CaSTLe ActiveRecord 建立在 NHibernate 之上,AR 的特性严重依赖于 NHibernate 的特性。 NHibernate 包含几个主键生成器:
1. 本地 - 这是默认生成器。如果您指定此项,则 NHibernate 会根据底层数据库自动选择生成器类型。例如,如果我在上面的映射片段中使用 native 而不是标识,您仍然会得到相同的 SQL,因为 NHibernate 足够聪明,可以理解底层数据库 SQL Server 并且它支持标识列。 NHibernate 使用 Convert.ChangeType 方法转换返回值。
2. 身份 - 这可以与 SQL Server、MySQL、Sybase 等提供的标识列一起使用,
3. 序列 - Firebird、DB2、PostgreSQL、Oracle、SAP DB 支持序列
4. 增量 - 此生成器不使用任何数据库功能,如序列或身份。 NHibernate 自动将 1 增加到最后一个主键值。这个生成器在处理单个数据库系统时很有用,但在基于集群的环境中没有帮助。
5. 希洛 - Hi/Lo 算法用于生成主键值。与其他生成器类型相比,这是非常有效的。使用时,NHibernate 创建一个名为 hibernate_unique_key 的单独表并创建一个名为 next_hi 的列,然后当 INSERT 发生时,NHibernate 使用该表作为引用。我们将在本文后面详细讨论这一点。
6. uuid.hex - 使用 System.Guid 及其 ToString 方法生成基于字符串的主键值。
7. 指导 - 这可以在类属性类型为 Guid 时使用。
8. guid.comb - 这与 guid 类似,但使用不同的算法来生成主键值。请注意,uuid.hex、guid、guid.comb 使用 UNIQUEIDENTIFIER 作为 SQL Server 中的列数据类型。
9. 已分配 - 最后但并非最不重要的是,此生成器假定主键值是由用户分配的。
所以你可以看到没有这样的内置功能。为了创建订单号,您可以使用两种方式:
1.选择最大订单并手动设置
2. 向数据库添加一些插入触发器
在我看来,您应该使用第一种方式,因为这样您就不会依赖数据库。当您需要向上或向下移动对象时,您可以重复使用此功能。我一般都是用这种方式。
关于activerecord - CaSTLe ActiveRecord 播种主键值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/575069/
我正在实现 hangFire,它是我项目中的作业调度库。 我面临着与此 link 中相同的问题 然而,将 LifestylePerWebRequest() 替换为 HybridPerWebReques
在我的项目中,我需要同时使用 CaSTLe.Windsor 和 Moq dll。 Windsor 要求 CaSTLe.Core 也在项目中被引用。 当我尝试使用 CaSTLe.Core 中的方法时,问
我已将我的解决方案从城堡版本 1.0 更新到版本 3.0,现在我收到此错误: Type Castle.Facilities.FactorySupport.FactorySupportFacility
我的应用程序使用“SignalR”客户端/服务器通信框架。如果您不熟悉它,服务器端应用程序通常包含一个或多个“集线器”类(类似于 asmx 网络服务),每个类都提供可由客户端调用的方法。在启动期间,客
假设我有这样的组件 public class MyComponent { public MyComponent(string name) { } } 我基本上想让提供的构造函数
我想知道是否有一些最佳实践来实现我需要的功能。 我有一个 Web 应用程序,它在启动期间通过反射扫描某些程序集(插件)并针对公共(public)内核注册它们的依赖项。 外部库可能需要相同的依赖项。 例
我想知道是否有一些最佳实践来实现我需要的功能。 我有一个 Web 应用程序,它在启动期间通过反射扫描某些程序集(插件)并针对公共(public)内核注册它们的依赖项。 外部库可能需要相同的依赖项。 例
是否有关于如何使用 CaSTLe Windsor 的自动事务管理的任何简单示例? documentation似乎缺少一些信息。我看到有用于 nHibernate、ActiveRecord 等的工具……
这是一次回答,但从那时起下载站点已经改变(显然)。我根本找不到 CaSTLe.MicroKernel。 2.51 不能再下载,它不在 2.52 中。或 2.53。 最佳答案 没有Castle.Micr
我正在将我们的项目从 .Net 2 升级到 .Net4.5,同时我将尽可能多的引用推送到 NuGet 并确保版本是最新的。 我在运行其中一项测试时遇到问题 测试类: public cl
当我开始使用 Windsor 时,我认为 DI 会很简单。现在它让我越来越困惑。 在我看来,存储库是一个具有单例生命周期的类。我应该有一个 FooRepository 实例来在应用程序的生命周期内将
我有一个接口(interface) ISession,其实例由不同的 session 工厂生成,具体取决于类所属的命名空间。 我的组件注册示例: IWindsorContainer container
我正在关注 example by José F. Romaniello使用 NHibernate 进行 session 管理。这是一篇非常好的文章,但是我在 NHibernate、Windsor 和
我有一个看似简单的用例。有一个 ICsvReader 组件。让我们在这里简单地将它命名为 Reader。我们加载了一组已知的 CSV 文件,其中一些有标题,有些没有。目前有多个阅读器:Reader_S
试图找出这件事的真正原因,但并没有太多乐趣! Type is not resolved for member 'Castle.MicroKernel.Lifestyle.Scoped.CallCont
这是我在 Global.asax 中的代码 WindsorContainer container = new WindsorContainer(); container.Register(Compo
我正在尝试了解如何使用 CaSTLe ActiveRecord 执行自定义查询。 我能够运行返回我的实体的简单查询,但我真正需要的是如下所示的查询(带有自定义字段集): 选择 count(1) 作为
在使用 ArrayResolver 时,如果我注册了一个接口(interface)的多个实现和一个依赖于所述接口(interface)数组的类,我希望数组解析器注入(inject)所有可以成功解析的接
我为服务注册了两个组件: container.Register( Component.For().Named("FirstChoice").ImplementedBy... Compo
有没有人有一些使用城堡 Windsor InstallerFactory 来订购安装程序的示例代码? 似乎无法在文档或其他地方找到它。 干杯 最佳答案 您只能使用 InstallerFactory与
我是一名优秀的程序员,十分优秀!