asp.net后台连oracle数据库,在插入记录后如何返回刚产生的ID值?

procedure123 2011-07-22 10:59:41


Begin

INSERT INTO WalkInfo_TaskList (Id ,ProjectNo, TaskType, TaskPara, TaskResult, TaskState, TaskPriority, UserId, CreateTime, EndTime)
VALUES (WALKINFO_TASKLISTID.Nextval, '123' , 1, 'xxxx', 'ssss', 1, 0, 123, Sysdate, Null);

Select WALKINFO_TASKLISTID.Currval From dual ;

End;



这个是在asp.net后台的一个SQL语句,去掉begin end发现在PL/SQL里能正确执行,但是无法用程序发送到数据库执行并返回数据,
加上begin end 后报select 语句缺少into
该如何解决呢?
...全文
225 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
子夜__ 2011-07-24
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 procedure123 的回复:]

引用 5 楼 wxr0323 的回复:
自增长的么
select @@IDENTITY

select max(id)...

第一个是SQL SERVER里的,不是我要的oracle的答案
第二个会引起并发产生的错误,比如在执行select max(id)之前,别人又使用了序列插入了一个ID,
那么select max(id)查到的就是别人新插入的ID,而不是自己刚刚所用的ID……
[/Quote]


那只能用returning了
returning SPLYBUREAUID;
procedure123 2011-07-23
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 wxr0323 的回复:]
自增长的么
select @@IDENTITY

select max(id)...
[/Quote]
第一个是SQL SERVER里的,不是我要的oracle的答案
第二个会引起并发产生的错误,比如在执行select max(id)之前,别人又使用了序列插入了一个ID,
那么select max(id)查到的就是别人新插入的ID,而不是自己刚刚所用的ID
所以你的两个'答案都是无效的
诺维斯基 2011-07-22
  • 打赏
  • 举报
回复
把你的id列设置为 int output;
procedure123 2011-07-22
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 fangyuantdy 的回复:]
如果你的主键可以用Guid的话就换吧,产生了Guid再插入DB中
[/Quote]
我就是想知道如何返回刚产生的自增长ID的值
fangyuantdy 2011-07-22
  • 打赏
  • 举报
回复
如果你的主键可以用Guid的话就换吧,产生了Guid再插入DB中
子夜__ 2011-07-22
  • 打赏
  • 举报
回复
自增长的么
select @@IDENTITY

select max(id)...
procedure123 2011-07-22
  • 打赏
  • 举报
回复
看来连oracle的很少啊?

62,266

社区成员

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

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

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

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