2016-09-30 2 views
1

イムなしでアクセスでリンクされたテーブルに挿入し、私のクエリでは、これが正常に動作し、新しいキーを使用してテーブル内のすべてのレコードをアップロード以下、Access 2007でリンクSQLテーブルに挿入しようとし、主キー

INSERT INTO tblProducts (ProductPrefix, ProductCode, ProductDescription, MadeFrom, MadeFromDescription, SamFamilySort1, SamFamilySort2, SamFamilySort3, SamFamilySort4, SamFamilySort5, Grade, Length, Thickness, fWidth, Factor, CubicMtrs, CubicMtrsFull, [Weight(T)], DrawingFilepath, EFACSProductGrouping, BatchSize, PackSize, Density, createdby, createddate, ProductType, customer, DimA, DimB, DimC, DimD, DimE, DimF, DimG, DimH, DimI, DimJ, DimK, DimL, DimM, DimN, DimO, DimP, DimQ, DimR, DimS, DimT, DimU, DimV, DimW, DimX, DimY, DimZ, TolA, TolB, TolC, TolD, TolE, TolF, TolG, TolH, TolI, TolJ, TolK, TolL, TolM, TolN, TolO, TolP, TolQ, TolR, TolS, TolT, TolU, TolV, TolW, TolX, TolY, TolZ, Dimension, Main, Saws, Moulders, PaintLines, XCut, DET, Wrapper, Blocks, HingeRecess, reorderpolicy, machinedaway, UseOtherM3XC, UseOtherM3MS, ShrinkWrap, ShrinkWrapPackSize, SW, samtype1, vtype1, vtype2, profile, productchamp, UOM, SAMPartGrp, PostingClass, ProductID) 
SELECT DISTINCT tblProducts.ProductPrefix, tblProducts.ProductCode, tblProducts.ProductDescription, tblProducts.MadeFrom, tblProducts.MadeFromDescription, tblProducts.SamFamilySort1, tblProducts.SamFamilySort2, tblProducts.SamFamilySort3, tblProducts.SamFamilySort4, tblProducts.SamFamilySort5, tblProducts.Grade, tblProducts.Length, tblProducts.Thickness, tblProducts.fWidth, tblProducts.Factor, tblProducts.CubicMtrs, tblProducts.CubicMtrsFull, tblProducts.[Weight(T)], tblProducts.DrawingFilepath, tblProducts.EFACSProductGrouping, tblProducts.BatchSize, tblProducts.PackSize, tblProducts.Density, tblProducts.createdby, Date() AS Expr1, tblProducts.ProductType, tblProducts.customer, tblProducts.DimA, tblProducts.DimB, tblProducts.DimC, tblProducts.DimD, tblProducts.DimE, tblProducts.DimF, tblProducts.DimG, tblProducts.DimH, tblProducts.DimI, tblProducts.DimJ, tblProducts.DimK, tblProducts.DimL, tblProducts.DimM, tblProducts.DimN, tblProducts.DimO, tblProducts.DimP, tblProducts.DimQ, tblProducts.DimR, tblProducts.DimS, tblProducts.DimT, tblProducts.DimU, tblProducts.DimV, tblProducts.DimW, tblProducts.DimX, tblProducts.DimY, tblProducts.DimZ, tblProducts.TolA, tblProducts.TolB, tblProducts.TolC, tblProducts.TolD, tblProducts.TolE, tblProducts.TolF, tblProducts.TolG, tblProducts.TolH, tblProducts.TolI, tblProducts.TolJ, tblProducts.TolK, tblProducts.TolL, tblProducts.TolM, tblProducts.TolN, tblProducts.TolO, tblProducts.TolP, tblProducts.TolQ, tblProducts.TolR, tblProducts.TolS, tblProducts.TolT, tblProducts.TolU, tblProducts.TolV, tblProducts.TolW, tblProducts.TolX, tblProducts.TolY, tblProducts.TolZ, tblProducts.Dimension, tblProducts.Main, tblProducts.Saws, tblProducts.Moulders, tblProducts.PaintLines, tblProducts.XCut, tblProducts.DET, tblProducts.Wrapper, tblProducts.Blocks, tblProducts.HingeRecess, tblProducts.reorderpolicy, tblProducts.machinedaway, tblProducts.useotherm3XC, tblProducts.useotherm3MS, tblProducts.ShrinkWrap, tblProducts.ShrinkWrapPackSize, tblProducts.SW, tblProducts.samtype1, tblProducts.vtype1, tblProducts.vtype2, tblProducts.profile, tblProducts.productchamp, tblProducts.UOM, tblProducts.SAMPartGrp, tblProducts.PostingClass, tblProducts.ProductID 
FROM tblProducts 

です私が(私はしない)したい場合。私は、[1つの製品だけアイブは、テストが、私はテーブル内の私の主キーが呼び出されたenter image description here

下のエラーを取得するユーザーエントリ

ためpopupboxある

以下
WHERE (((tblProducts.ProductID)=[tests])); 

を追加しようとした再作成したいです製品番号]。 WHERE [ProductID] = 1234をこのクエリに何らかの形で追加することは可能ですか?

+0

テストとは何ですか?誰でも手伝うことができる情報は事実上提供していません。私があなたを手伝ってくれるのと同じくらい、私は単に情報が足りないだけです。 –

+0

Sorry testsは、ユーザーが変数を入力するポップアップボックスです。私はAutonumberとしてProductIDを挿入したくないのですが、ユーザーが指定する1行をProductIDというポップアップボックスを使って挿入するだけです。それが意味をなさないならば。 – Bunion

+0

もちろん、プライマリキー違反が発生しています。正確に同じ行をテーブルに挿入し直しています。また、クエリのパラメータ化を見たいと思うかもしれません。あなたの例はSQLインジェクションに広く開いています。 –

答えて

1

INSERT INTO句の最後の項目がProductIDであることに注意してください。したがって、既存の主キー値を使用して新しい行を挿入しようとしていますが、これは機能しません。簡単な例として、

INSERT INTO tblProducts (ProductDescription, ProductID) 
SELECT tblProducts.ProductDescription, tblProducts.ProductID 
FROM tblProducts 
WHERE tblProducts.ProductID=1 

は、主キー違反で失敗します。 ProductIDをINSERT INTO句とSELECT句の両方から削除し、WHERE句でのみProductIDを削除する必要があります。

INSERT INTO tblProducts (ProductDescription) 
SELECT tblProducts.ProductDescription 
FROM tblProducts 
WHERE tblProducts.ProductID=1 
+0

私はばかだよ。どうもありがとうございます! – Bunion

関連する問題