Solved

Creation of duplicate values in the index, primarykey or relationship using ASP

Posted on 2006-07-13
1
267 Views
Last Modified: 2006-11-18
Hi,

  I am working with ASP on Access Database and tried inserting a new record into the database but encountered the following error:

Microsoft OLE DB Provider for ODBC Drivers error '80040e14'

[Microsoft][ODBC Microsoft Access Driver] The changes you requested to the table were not successful because they would create duplicate values in the index, primary key, or relationship. Change the data in the field or fields that contain duplicate data, remove the index, or redefine the index to permit duplicate entries and try again.

/admin/sys/table_change/joborder/jobatchdetail_new_ins.asp, line 79


I displayed the query for inserting into the table and I could see nothing wrong in the query.
Basically, I have a batchreturndetails table with batchreturndetailsid as the primary key. Before I insert a new record into the table, I retrieved the latest batchreturndetailsid, add 1 to it and include it in the insert statement. I could insert the first record. But it gives me the above problem for subsequent records.

The ASP code looks like this:

'Check for first record of repairdetail by country else find max value
Set rsbatchreturndetail=server.CreateObject("ADODB.Recordset")

qry="Select batchreturndetailid from batchreturndetail where countryid=" & strcountryid

rsbatchreturndetail.Open qry, oDBConn,3,3

if rsbatchreturndetail.eof then
    strbatchreturndetailid = 1
else
    qry1="Select max(batchreturndetailid) as batchreturndetailidmax from batchreturndetail where countryid=" & strcountryid
    'response.write qry1
end if

rsbatchreturndetail.close
set rsbatchreturndetail=nothing

if qry1<>"" then
    Set rsbatchreturndetailmax=server.CreateObject("ADODB.Recordset")
    rsbatchreturndetailmax.Open qry1, oDBConn,3,3
    if not rsbatchreturndetailmax.eof then
       strbatchreturndetailid=trim(rsbatchreturndetailmax("batchreturndetailidmax"))+1
    end if
    rsbatchreturndetailmax.close
    set rsbatchreturndetailmax=nothing
end if
'response.write "strbatchreturndetailid" & strbatchreturndetailid
'response.end

sqlcmd="Insert into batchreturndetail (batchreturndetailid,repairid,indexno,returndate,qty,abletorepairflag,unabletorepairflag,deleteflag,memberid,countryid,regdate)" & _
"values (" & strbatchreturndetailid & "," & strrepairid & "," & strindexno & ",#" & strreturndate & "#," & strqty & "," & strabletorepair & "," & _
strunabletorepair & ",0," & strmemberid & "," & strcountryid & ",#" & Now() & "#)"

'response.write sqlcmd
'response.end

oDBConn.Execute sqlcmd

My code works fine initally on my local PC but when I migrated to a remote server, it gave me the above errror.
Don't think it is the cursor error cos I use the same cursor for other parts of the code as well and it is working fine.

Many thanks for your advice
 
0
Comment
Question by:thaishin
1 Comment
 
LVL 77

Accepted Solution

by:
peter57r earned 500 total points
Comment Utility
Hi thaishin,
You are asking for the max id of records for a given country.
That says nothing about what records exist for other countries whose ids could be higher than the country you have asked for.

You need to get the max of all records irrespective of country.


Pete
0

Featured Post

Highfive Gives IT Their Time Back

Highfive is so simple that setting up every meeting room takes just minutes and every employee will be able to start or join a call from any room with ease. Never be called into a meeting just to get it started again. This is how video conferencing should work!

Join & Write a Comment

This article is a continuation or rather an extension from Cascading Combos (http://www.experts-exchange.com/A_5949.html) and builds on examples developed in detail there. It should be understandable alone, but I recommend reading the previous artic…
It took me quite some time to sort out all the different properties of combo and list boxes available from Visual Basic at run-time. Not that the documentation is lacking: the help pages are quite thorough and well written. The problem was rather wh…
Familiarize people with the process of retrieving data from SQL Server using an Access pass-thru query. Microsoft Access is a very powerful client/server development tool. One of the ways that you can retrieve data from a SQL Server is by using a pa…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…

728 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

13 Experts available now in Live!

Get 1:1 Help Now