我生成的SQL代码如下所示 -
INSERT INTO [Item] (
Vendor_num
, item
, [Desc]
, Pack
, item_size
, unit_of_sale
, allowance
, points
, Promo
, WS_Cost
, WS_Unit_cost
, Retailer_Price
, Retail
, Cust_Use
, Show_Price
, GP
, Min
, Max
, Book_Number
, Del1_date
, Del2_date
, Del3_date
, Del4_date
, Del5_date
, Del6_date
, Del7_date
, Del8_date
, Del9_date
, Del10_date
, Del11_date
, Del12_date
, Del13_date
, Del14_date
, Del15_date
, warehouse
, Purchase_Group
, GPM
, Material_Number
, PM
) VALUES (
'11'
, '300681'
, 'item description'
, '60'
, 'BOX'
, 'BOX'
, '3'
, '20'
, 'Y'
, '0'
, null
, '0'
, null
, '03652'
, null
, null
, null
, null
, '832'
, '6/2/2014 12:00:00 AM'
, '6/30/2014 12:00:00 AM'
, '7/28/2014 12:00:00 AM'
, '8/18/2014 12:00:00 AM'
, null
, null
, null
, null
, null
, null
, null
, null
, null
, null
, null
, '1'
, null
, null
, null
, null
)
(原谅所有这些null
值,它们在这些插入中经常不为空,因此当它们不是时,语句需要足够灵活
我收到了一般错误 -
An unhandled exception of type 'System.Data.OleDb.OleDbException' occurred in System.Data.dll
Additional information: Syntax error in INSERT INTO statement.
当直接复制到Access中的新查询时,该语句可以正常工作,但是当通过.NET和OLE DB触发时,它会失败。
有什么想法吗?
答案 0 :(得分:1)
Min
和Max
为reserved words in Access,如果您将它们用作字段名称或者您可能会遇到错误,则应引用它们;
如果已经使用了保留字,则可以通过括号([])包围每个单词的出现来避免出现错误消息。但是,最好的解决方案是将名称更改为非保留字。
换句话说,用作字段名称时,应引用[Min]
和[Max]
。