人人做人人澡人人爽欧美,国产主播一区二区,久久久精品五月天,羞羞视频在线观看免费

當前位置:蘿卜系統下載站 > 技術開發教程 > 詳細頁面

所有方面處理--如何獲得剛插入數據庫的記錄的ID號?

所有方面處理--如何獲得剛插入數據庫的記錄的ID號?

更新時間:2021-03-26 文章作者:未知 信息來源:網絡 閱讀次數:

如何獲得剛插入數據庫的記錄的ID號?

1.SQL Server
對于SQL Server 2000來說,它提供了兩個全新的函數(IDENT_CURRENT,SCOPE_IDENTITY),并且改進了@@IDENTITY的不足.當你插入新記錄后,可以調用函數:
PRINT IDENT_CURRENT('table') '這將獲得新的IDENTITY值,不管數據庫中是不是有記錄添加(這就避免了@@IDENTITY的連接限制)
或者:PRINT SCOPE_IDENTITY() '這將獲得在當前存儲過程,觸發器等其他程序創建的最新記錄的IDENTITY值.
而全局變量@@IDENTITY有一個問題,當對一張表執行insert時,如果該表有觸發器程序在執行插入操作,然后,接著在另一張表中插入記錄,這樣返回@@IDENTITY值就是第二張表的IDENTITY值。
如果你用的不是SQL Server 2000,你最好一個簡單的存儲過程來解決這個問題。
CREATE PROCEDURE myProc
@param1 INT
AS
BEGIN
SET NOCOUNT ON
INSERT INTO someTable
(
intField
)
VALUES
(
@param1
)
SET NOCOUNT OFF
SELECT NEWID = @@IDENTITY
END
在ASP中你可以這樣做:
<%
fakeValue = 5
set conn = Server.CreateObject("ADODB.Connection")
conn.open "<conn string>"
set rs = conn.execute("exec myProc @param1=" & fakeValue)
response.write "New ID was " & rs(0)
rs.close: set rs = nothing
conn.close: set conn = nothing
%>

2.Access
對于Access,你可以用下面這樣的方法:
<%
fakeValue = 5
set conn = Server.CreateObject("ADODB.Connection")
conn.open "<conn string>"
conn.execute "Insert into someTable(intField) values(" & fakeValue & ")"
set rs = conn.execute("select MAX(ID) from someTable")
response.write "New ID was " & rs(0)
rs.close: set rs = nothing
conn.close: set conn = nothing
%>
然而對于多人同時向數據庫中添加數據,我們就要利用記錄集的adOpenKeyset游標來防止出錯。例如下面的例子:
<%
fakeValue = 5
set conn = Server.CreateObject("ADODB.Connection")
conn.open "<conn string>"
set rs = Server.CreateObject("ADODB.Recordset")
rs.open "select [intField] from someTable where 1=0", conn, 1, 3
rs.AddNew
rs("intField") = fakeValue
rs.update
response.write "New ID was " & rs("id")
rs.close: set rs = nothing
conn.close: set conn = nothing
%>

溫馨提示:喜歡本站的話,請收藏一下本站!

本類教程下載

系統下載排行

網站地圖xml | 網站地圖html
主站蜘蛛池模板: 石楼县| 康乐县| 满城县| 沿河| 邵阳县| 江门市| 安义县| 卢龙县| 济南市| 上杭县| 长汀县| 德令哈市| 涞水县| 肥西县| 绥棱县| 保定市| 平乐县| 五大连池市| 德庆县| 湘潭市| 五峰| 会昌县| 西乌| 安泽县| 手游| 峨山| 定远县| 交口县| 凤城市| 观塘区| 循化| 西华县| 涟源市| 八宿县| 田东县| 丹棱县| 云安县| 鄄城县| 屯留县| 武宣县| 黄大仙区|