asp.net怎么实现自动编号

liao847 2011-12-25 11:30:50
各位大虾 怎么实现自动编号 这个编号是单据号 就是当前时间+号码 2011-12-25-0001如果是第二天变成2011-12-26-0001编号又从0001开始 各位大虾帮帮忙 急啊
...全文
459 15 打赏 收藏 转发到动态 举报
写回复
用AI写文章
15 条回复
切换为时间正序
请发表友善的回复…
发表回复
liao847 2011-12-28
  • 打赏
  • 举报
回复
谁帮帮我 我加你们qq啊
liao847 2011-12-28
  • 打赏
  • 举报
回复
触发器器不知道怎么用 我写的那个方法只能执行一次不能执行到第二次
小河 2011-12-28
  • 打赏
  • 举报
回复
顶起 触发器
bakdfkuk 2011-12-28
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 orain 的回复:]

还是使用触发器吧,不用担心并发时产生重复编号的问题。在关键数据上不要心存侥幸,认为用户数很少,就不会产生重复编号,我曾经在一个每天只会产生二三十笔数据的系统中,直接取最大值加一的方式产生编号,运行一年多以后,客户最终还是反映有两笔数据编号重了。
给你一个使用触发器的样例:
SQL code

ALTER TRIGGER [dbo].[Trigger_Insert]
ON [dbo……
[/Quote]

顶。。。。。。。。。。。。。。。。。。。。。。。。。。。
liao847 2011-12-28
  • 打赏
  • 举报
回复
protected void Autocode(string code)
{
System.DateTime da = System.DateTime.Now;
string dtime = Convert.ToString(da);
string stime = dtime.Substring(0, 10);

int billcode = Convert.ToInt32(code) + 1;
// Response.Write(billcode);
string scode = Convert.ToString(billcode);
if (scode.ToString().Length == 1)
{
t1.Text = "xf" + "-" + stime + "-" + "000" + scode;
string code11 = t1.Text.Substring(14, 4);

// Response.Write(code);
//Autocode(bcode);
}
if (scode.ToString().Length == 2)
{
t1.Text = "xf" + "-" + stime + "-" + "00" + scode;
}
if (scode.ToString().Length == 3)
{
t1.Text = "xf" + "-" + stime + "-" + "0" + scode;
}

}
liao847 2011-12-28
  • 打赏
  • 举报
回复
if (!IsPostBack)
{


System.DateTime da = System.DateTime.Now;
string dtime = Convert.ToString(da);
string stime = dtime.Substring(0, 10);
// t4.Text = stime;

string sql1 = "select * from t_bill where billcode like '%" + stime + "%'";



SqlConnection conn1 = new SqlConnection(sqlconn);
SqlCommand cmd1 = new SqlCommand(sql1, conn1);
conn1.Open();
if (cmd1.ExecuteScalar() != null)
{
//Response.Write(cmd1.ExecuteScalar().ToString());
SqlDataReader dr = cmd1.ExecuteReader();

dr.Read();
string bcode = Convert.ToString(dr["billcode"]).Substring(14, 4);

Autocode(bcode);

}
else
{
t1.Text = "xf" + "-" + stime + "-" + "0001";
}
}
liao847 2011-12-28
  • 打赏
  • 举报
回复
我把我做的给你们看
huijunliang 2011-12-26
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 orain 的回复:]
还是使用触发器吧,不用担心并发时产生重复编号的问题。在关键数据上不要心存侥幸,认为用户数很少,就不会产生重复编号,我曾经在一个每天只会产生二三十笔数据的系统中,直接取最大值加一的方式产生编号,运行一年多以后,客户最终还是反映有两笔数据编号重了。
给你一个使用触发器的样例:

SQL code

ALTER TRIGGER [dbo].[Trigger_Insert]
ON [……
[/Quote]


+1
myhope88 2011-12-26
  • 打赏
  • 举报
回复
用触发器的方式确实不错
orain 2011-12-25
  • 打赏
  • 举报
回复
当然,你也可以在读取最大编号时就对数据加锁,一直到写入编号后解锁,但这会对性能造成一定的影响。
orain 2011-12-25
  • 打赏
  • 举报
回复
还是使用触发器吧,不用担心并发时产生重复编号的问题。在关键数据上不要心存侥幸,认为用户数很少,就不会产生重复编号,我曾经在一个每天只会产生二三十笔数据的系统中,直接取最大值加一的方式产生编号,运行一年多以后,客户最终还是反映有两笔数据编号重了。
给你一个使用触发器的样例:

ALTER TRIGGER [dbo].[Trigger_Insert]
ON [dbo].[TableA]
After INSERT
AS
BEGIN
declare @pkid int,@pid varchar(14),@temppid varchar(14)
--从Inserted表中取得主键的自动编号
select @pkid=pkid from Inserted
--获取当前日期格式为"P20081010"
select @pid = 'P' + Convert(varchar(8),GetDate(),112);
--获取最后一个PID
select top 1 @temppid=pid from TableA where pid like @pid+'%' order by pkid desc
if (@temppid is null)
begin
--如果今天没有插入过数据,则初始值为'P200810100001'
set @pid = @pid + '0001'
end
else
begin
--否则从最后一个日期取得编号,并末尾加上1,组成新编号
set @pid = @pid + right(cast(power(10,4) as varchar)+(convert(int,substring(@temppid,10,4))+1),4)
end
--更新编号
update TableA set pid=@pid where pkid = @pkid
END
dalmeeme 2011-12-25
  • 打赏
  • 举报
回复
从数据库中取出当天的最大号码,如果不存在,则int n=0;

如果存在,则n=最大号码+1;(注意substring得到最后四位,转成int)

string code=n.ToString("D4");

code=DateTime.Now.ToString("yyyy-MM-dd")+"-"+code;

写入数据库
wuyq11 2011-12-25
  • 打赏
  • 举报
回复
DataTime.Now.ToString("yyyy-MM-dd')+获取最大编号.PadLeft('0',4);
或在sql里使用getdate生成编号

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧