<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
        {font-family:Consolas;
        panose-1:2 11 6 9 2 2 4 3 2 4;}
@font-face
        {font-family:Verdana;
        panose-1:2 11 6 4 3 5 4 4 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0cm;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri",sans-serif;
        mso-fareast-language:EN-US;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:#0563C1;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:#954F72;
        text-decoration:underline;}
span.EmailStyle17
        {mso-style-type:personal;
        font-family:"Calibri",sans-serif;
        color:windowtext;}
span.EmailStyle18
        {mso-style-type:personal-reply;
        font-family:"Calibri",sans-serif;
        color:#1F497D;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;}
@page WordSection1
        {size:612.0pt 792.0pt;
        margin:72.0pt 72.0pt 72.0pt 72.0pt;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-AU" link="#0563C1" vlink="#954F72">
<div class="WordSection1">
<p class="MsoNormal">Hello World,<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Ingres Release II 10.2.0 (int.w32/100).<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">I have in interesting problem. We have been successfully using .NET Data Provider 2.1 for a while to select data and never had a problem, however we have never needed to update/insert until recently because we do all that through OpenROAD
Server. Recently my colleague wrote an insert that works fine, but when I copied his approach it always fails. The InsertCommand.ExecuteNonQuery() raises an exception with the message “Connection closed”. When I check the errlog.log on the server, it states
“E_GC4807_CONN_ABORT Aborting client connection, reason follows” and “E_US0005 Could not open the iirelation table”.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Here is a sample of my code:<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue;background:white;mso-highlight:white">using</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> (</span><span style="font-size:9.5pt;font-family:Consolas;color:blue;background:white;mso-highlight:white">var</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
iiConnection = </span><span style="font-size:9.5pt;font-family:Consolas;color:blue;background:white;mso-highlight:white">new</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF;background:white;mso-highlight:white">IngresConnection</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">(ConnectionString))<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> {<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> iiConnection.Open();<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue;background:white;mso-highlight:white">var</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> mqt = iiConnection.BeginTransaction(</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF;background:white;mso-highlight:white">IsolationLevel</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">.RepeatableRead);<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:green;background:white;mso-highlight:white">// Check that a select works inside the MQT prior to the insert which is failing.</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"><o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue;background:white;mso-highlight:white">var</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> dataReader =
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue;background:white;mso-highlight:white">new</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF;background:white;mso-highlight:white">IngresCommand</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">(</span><span style="font-size:9.5pt;font-family:Consolas;color:maroon;background:white;mso-highlight:white">@"SELECT
late_date FROM cdat"</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">, iiConnection, mqt).ExecuteReader();<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue;background:white;mso-highlight:white">while</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> (dataReader.Read())<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> {<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue;background:white;mso-highlight:white">var</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> appDate =
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF;background:white;mso-highlight:white">Convert</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">.ToDateTime(</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF;background:white;mso-highlight:white">DataTypeHelpers</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">.GetIIDate(dataReader.GetValue(0)));<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> }<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> dataReader.Close();<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> _query =
</span><span style="font-size:9.5pt;font-family:Consolas;color:maroon;background:white;mso-highlight:white">@"INSERT INTO cdat (late_date) VALUES ("</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> +
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF;background:white;mso-highlight:white">DateTime</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">.Today +
</span><span style="font-size:9.5pt;font-family:Consolas;color:#A31515;background:white;mso-highlight:white">")"</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">;<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue;background:white;mso-highlight:white">var</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> ingresDataAdapter =
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue;background:white;mso-highlight:white">new</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF;background:white;mso-highlight:white">IngresDataAdapter</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> { InsertCommand =
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue;background:white;mso-highlight:white">new</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF;background:white;mso-highlight:white">IngresCommand</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">(_query, iiConnection, mqt)
};<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:green;background:white;mso-highlight:white">// This insert causes an exception. The message is “Connection closed”.</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"><o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue;background:white;mso-highlight:white">if</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> (ingresDataAdapter.InsertCommand.ExecuteNonQuery()
== 0)<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> {<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:#2B91AF;background:white;mso-highlight:white">Log</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">.Error(</span><span style="font-size:9.5pt;font-family:Consolas;color:#A31515;background:white;mso-highlight:white">"No
row inserted into CDAT unexpectedly"</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">);<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> mqt.Rollback();<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue;background:white;mso-highlight:white">return</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">
</span><span style="font-size:9.5pt;font-family:Consolas;color:blue;background:white;mso-highlight:white">false</span><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white">;<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> }<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> mqt.Commit();<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"><o:p> </o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> iiConnection.Close();<o:p></o:p></span></p>
<p class="MsoNormal" style="text-autospace:none"><span style="font-size:9.5pt;font-family:Consolas;color:black;background:white;mso-highlight:white"> }<o:p></o:p></span></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">Any help would be much appreciated.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><span lang="EN-US" style="color:#1F497D;mso-fareast-language:EN-AU">Regards,<o:p></o:p></span></p>
<p class="MsoNormal"><span lang="EN-US" style="font-size:10.0pt;font-family:"Verdana",sans-serif;color:#1F497D;mso-fareast-language:EN-AU"><o:p> </o:p></span></p>
<p class="MsoNormal"><b><span lang="EN-US" style="font-size:9.0pt;font-family:"Verdana",sans-serif;color:#00B0F0;mso-fareast-language:EN-AU">James Higson<o:p></o:p></span></b></p>
<p class="MsoNormal" style="margin-top:6.0pt"><b><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#656565;mso-fareast-language:EN-AU">Consulting Director</span></b><span style="font-size:8.5pt;font-family:"Times New Roman",serif;color:#1F497D;mso-fareast-language:EN-AU"><br>
</span><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#00B0F0;mso-fareast-language:EN-AU">SAASie Hosting (</span><span style="font-size:8.0pt;font-family:"Verdana",sans-serif;color:#00B0F0;mso-fareast-language:EN-AU">A Division of
</span><span style="font-size:8.0pt;font-family:"Verdana",sans-serif;color:red;mso-fareast-language:EN-AU">GUI</span><span style="font-size:8.0pt;font-family:"Verdana",sans-serif;color:#00B0F0;mso-fareast-language:EN-AU">-</span><i><span style="font-size:8.0pt;font-family:"Verdana",sans-serif;color:#33CCCC;mso-fareast-language:EN-AU">tek</span></i><span style="font-size:8.0pt;font-family:"Verdana",sans-serif;color:#33CCCC;mso-fareast-language:EN-AU">
Consulting</span><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#00B0F0;mso-fareast-language:EN-AU">)</span><span style="color:#1F497D;mso-fareast-language:EN-AU"><o:p></o:p></span></p>
<p class="MsoNormal"><b><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#656565;mso-fareast-language:EN-AU">Bus</span></b><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#1F497D;mso-fareast-language:EN-AU"> </span><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#656565;mso-fareast-language:EN-AU">+61
3 9578 9307 |</span><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#1F497D;mso-fareast-language:EN-AU"> </span><b><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#656565;mso-fareast-language:EN-AU">Home</span></b><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#1F497D;mso-fareast-language:EN-AU"> </span><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#656565;mso-fareast-language:EN-AU">+61
3 9502 7700 |</span><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#1F497D;mso-fareast-language:EN-AU"> </span><b><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#656565;mso-fareast-language:EN-AU">Mob</span></b><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#1F497D;mso-fareast-language:EN-AU"> </span><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#656565;mso-fareast-language:EN-AU">+61
417 185 980<br>
<b>Email </b></span><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:blue;mso-fareast-language:EN-AU"><a href="mailto:james.higson@saasie.net.au"><span style="color:blue">james.higson@saasie.net.au</span></a></span><span style="font-size:8.5pt;font-family:"Verdana",sans-serif;color:#1F497D;mso-fareast-language:EN-AU"><o:p></o:p></span></p>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
</body>
</html>