** 背景 **
每天的订单数都是从0开始的,每生成一个订单,订单数就应该加1.订单数应该是持久的,写在Session中或者Memcached缓存中,当网站重启或者服务器重启时都会面临丢失的问题,所以只能存在数据库中。幸好Oracle数据库提供了Sequence(序列)功能,我们来看下Sequence(序列)的概述及其用法。
** 概述 **
** 基本用法 **
下面我们就来看EF的DbContext具体使用:
** 1. 判断是否存在名为ODORDER
的序列 **
int count = context.Database.SqlQuery<int>("SELECT count(*) FROM All_Sequences where Sequence_name='ODORDER'").FirstOrDefault()
如数据库中存在该序列,则返回的数值应大于0。
** 2. 每天的订单数都应该是从新开始的,所以简单做法如果存在ODORDER
该序列,我们先删除. **
context.Database.ExecuteSqlCommand("DROP SEQUENCE ODORDER")
** 3. 创建名为ODORDER
的序列 **
context.Database.ExecuteSqlCommand("CREATE SEQUENCE ODORDER INCREMENT BY 1 START WITH 100000 MAXVALUE 900000 MINVALUE 100000 CYCLE CACHE 20 ");
** 4. 获取最新订单数 **
context.Database.SqlQuery<int>("select ODORDER.nextval from dual").FirstOrDefault()
原创文章,如有转摘请注明来源!