c#获取对象的唯一标识_标识的重要性,教你使用键表方式生成标识。

标识域(identity identity),Evans 这样说到  我们通过标识对对象进行区分,而不是属性,此时我们应该将标识作为主要的模型定义。同时我们需要保持简单的类定义,并且关注对象在其生命周期中的连续性和唯一性。我们不应该通过对象的状态形式和历史来区分不同的实体对象。 我们经常会犯这样的错误,当对一个对象进行建模时,我们自然而然会考虑它的属性,而且考虑它的行为,不能说行为并不重要。但实体最基本的职责是确保连续性,以便使其行为更清楚且可预测。保持实体店简练是实现这一责任的关键。 因此,一个实体的唯一性标识变得很重要。比如,叫张三的人太多了,不能通过名字来区分。 通常实现一个唯一性标记有三种选择: 1、数据库自动生成; 2、使用 GUID; 3、自己写一个; 数据库自动生成是最简单的。在关系型数据库中,我们通常在设计建立表的时候,会对其建立一个主键,并设置成自增长。每次你要往数据库里面插入数据,数据库会自增长成一个新值,不需要你做任何事情。 但是,这个策略的问题在于难以确定的是生成的是什么值。相信大家编写应用程序时,经常会遇到如下场景将某数据插入到数据库中,需要返回该条数据的标识域(Identity Field),将标识给到关联业务作为外键,然后关联业务进行下一步操作。 比如,要插入一份包含多条子项的订单,那么就需要新订单的键值,作为订单项的外键。假如,业务复杂一点,每个订单项都有相应的提成员工,这个时候订单项也要返回新订单项的键值。这一系列的操作必须在事务提交之前要知道相应的键值,这样才能保存事务中的所有记录。每一步动作都需要等到上一步操作完之后,才能进行下一步,这样会造成一个很长的事务。我们经常会使用如下的方式进行操作,通过插入数据返回主键ID。
jdbcTemplate.update(new PreparedStatementCreator() {
    @Override    public PreparedStatement createPreparedStatement(Connection conn) throws SQLException {
    
PreparedStatement ps = conn.prepareStatement(orderSQL.toString(), Statement.RETURN_GENERATED_KEYS);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值