<?xml version="1.0" encoding="UTF-8" ?>
<?xml-stylesheet type="text/xsl" href="https://www.dotnetzone.gr:443/cs/utility/FeedStylesheets/rss.xsl" media="screen"?><rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/" xmlns:wfw="http://wellformedweb.org/CommentAPI/"><channel><title>Πρώτα Βήματα - Βάσεις δεδομένων</title><link>https://www.dotnetzone.gr:443/cs/forums/73/ShowForum.aspx</link><description>Για όσους κάνουν τα πρώτα τους βήματα στην Microsoft Access ή τον SQL Server, ή γενικότερα στη θεωρία βάσεων δεδομένων.</description><dc:language>el</dc:language><generator>CommunityServer 2.1 SP3 (Build: 20423.1)</generator><item><title>Απ: OdbcCommand και named parameters</title><link>https://www.dotnetzone.gr:443/cs/forums/thread/31699.aspx</link><pubDate>Thu, 10 May 2007 23:46:03 GMT</pubDate><guid isPermaLink="false">2622095e-976c-431a-859e-16783ec7ecd7:31699</guid><dc:creator>Παναγιώτης Καναβός</dc:creator><slash:comments>0</slash:comments><comments>https://www.dotnetzone.gr:443/cs/forums/thread/31699.aspx</comments><wfw:commentRss>https://www.dotnetzone.gr:443/cs/forums/commentrss.aspx?SectionID=73&amp;PostID=31699</wfw:commentRss><description>&lt;P&gt;Θα συμφωνήσω με τον Μανώλη. Δεν υπάρχει κανένας λόγος να χρησιμοποιεί κανείς ODBC. Μάλιστα, η Microsoft έχει πάψει να αναπτύσσει το ODBC (της Microsoft είναι) εδώ και πολλά χρόνια. Συνεπώς, είναι πάντα η πιο αργή και προβληματική λύση.&lt;/P&gt;
&lt;P&gt;Ο λόγος που το ODBC ακούγεται ακόμα και δεν έχει εξαφανιστεί, είναι ότι είναι το μοναδικό στάνταρ στο οποίο κατάφεραν να συμφωνήσουν οι εταιρείες βάσεων δεδομένων. Έτσι υπάρχουν ODBC drivers για όλες τις βάσεις και όλα τα λειτουργικά. Πριν από 10 χρόνια όμως, η Microsoft έβγαλε το διάδοχο του ODBC, το OLEDB το οποίο απαιτούσε την ύπαρξη Windows. Οι βάσεις που έτρεχαν σε άλλα λειτουργικά δεν ακολούθησαν τη Microsoft, με αποτέλεσμα οι βάσεις που τρέχουν σε λειτουργικά Unix και Linux να χρησιμοποιούν το ODBC ακομα και σήμερα. Επειδή όμως είναι παλιό και αργό, έχουν βγεί μερικά πολύ ακριβά "middleware" συστήματα με σκοπό να επιταχύνουν την επικοινωνία των εφαρμογών με τις βάσεις, παρακάμπτωντας όπου μπορούν το ODBC.&lt;/P&gt;
&lt;P&gt;Στα Windows, το OLEDB έχει αντικατασταθεί και αυτό από τους Managed Providers για .NET, οι οποίοι πετυχαίνουν ακόμα μεγαλύτερη ταχύτητα, καθώς επικοινωνούν απευθείας με τη βάση, παρακάμπτωντας το ενδιάμεσο στάδιο του OLEDB.&lt;/P&gt;</description></item><item><title>Απ: OdbcCommand και named parameters</title><link>https://www.dotnetzone.gr:443/cs/forums/thread/31690.aspx</link><pubDate>Thu, 10 May 2007 20:33:22 GMT</pubDate><guid isPermaLink="false">2622095e-976c-431a-859e-16783ec7ecd7:31690</guid><dc:creator>KelMan</dc:creator><slash:comments>0</slash:comments><comments>https://www.dotnetzone.gr:443/cs/forums/thread/31690.aspx</comments><wfw:commentRss>https://www.dotnetzone.gr:443/cs/forums/commentrss.aspx?SectionID=73&amp;PostID=31690</wfw:commentRss><description>&lt;P&gt;Όχι δεν μπορείς. Αυτό το υποστηρίζει μόνο ο SqlClient. Εφόσον παίζεις σε SQL Server, γιατί δεν χρησιμοποιείς SqlClient? Έχει πολλά πλεονεκτήματα η χρήση του πέρα από την υποστήριξη named parameters όπως γρηγορότερη επικοινωνία, αντιστοιχία των τύπων με αυτούς του SQL Server, κλπ.&lt;/P&gt;</description></item><item><title>OdbcCommand και named parameters</title><link>https://www.dotnetzone.gr:443/cs/forums/thread/31689.aspx</link><pubDate>Thu, 10 May 2007 20:24:41 GMT</pubDate><guid isPermaLink="false">2622095e-976c-431a-859e-16783ec7ecd7:31689</guid><dc:creator>dva</dc:creator><slash:comments>0</slash:comments><comments>https://www.dotnetzone.gr:443/cs/forums/thread/31689.aspx</comments><wfw:commentRss>https://www.dotnetzone.gr:443/cs/forums/commentrss.aspx?SectionID=73&amp;PostID=31689</wfw:commentRss><description>&lt;p&gt;Γειά σας,&lt;/p&gt;&lt;p&gt;Προσπαθώ να εκτελέσω ένα OdbcCommand με κάποιες παράμετρους αλλά μου βγάζει πρόβλημα.&lt;/p&gt;&lt;p&gt;Εχω το εξής command (προσθέτω παρακάτω τις παραμέτρους P1 και P0).&lt;br&gt;&lt;/p&gt;&lt;p style="font-family:courier new,courier;"&gt;UPDATE mytable SET myText=@P1 WHERE ID=@P0&lt;/p&gt;&lt;p&gt;Αλλά όταν το εκτελώ μου βγάζει exception&lt;/p&gt;&lt;p&gt;&lt;span style="font-family:courier new,courier;"&gt;ERROR [42000] [Microsoft][ODBC SQL Server Driver][SQL Server]Must declare the variable '@P1'.&lt;/span&gt;&amp;nbsp;&lt;/p&gt;&lt;p&gt;Αν χρησιμοποιήσω unnamed parameters, όμως μου τρέχει κανονικά.&lt;/p&gt;&lt;p style="font-family:courier new,courier;"&gt;UPDATE mytable SET myText=? WHERE ID=?&lt;/p&gt;&lt;p&gt;Μπορώ να χρησιμοποιήσω named parameters σε OdbcCommands (και πώς) ώστε αν αλλάξει το query να μην χρειάζεται να αλλάζω και τη σειρά των παραμέτρων.&lt;br&gt;&lt;/p&gt;&lt;p&gt;(Η βάση είναι σε SQL Server 2000).&lt;br&gt;&amp;nbsp;&lt;/p&gt;</description></item></channel></rss>