<?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>Απ: ΕΦΑΡΜΟΓΗ ΜΕ SQL SERVER και πρόβλημα με ελληνικούς χαρακτήρες...</title><link>https://www.dotnetzone.gr:443/cs/forums/thread/72893.aspx</link><pubDate>Fri, 07 Jun 2013 16:11:15 GMT</pubDate><guid isPermaLink="false">2622095e-976c-431a-859e-16783ec7ecd7:72893</guid><dc:creator>George J. Capnias</dc:creator><slash:comments>0</slash:comments><comments>https://www.dotnetzone.gr:443/cs/forums/thread/72893.aspx</comments><wfw:commentRss>https://www.dotnetzone.gr:443/cs/forums/commentrss.aspx?SectionID=73&amp;PostID=72893</wfw:commentRss><description>&lt;BLOCKQUOTE&gt;&lt;div&gt;&lt;img src="http://www.dotnetzone.gr/cs/Themes/default/images/icon-quote.gif"&gt; &lt;strong&gt;paolo75gr:&lt;/strong&gt;&lt;/div&gt;&lt;div&gt;&lt;p&gt;Λογικά θα έπρεπε να αναγνωρίζει τους ελληνικούς χαρακτήρες η βάση γνωρίζεται αν πρέπει εκτος απο κωδικά που πρέπει να γραφτεί, αν οι ρυθμίσεις που έχω κάνει είναι σωστές.&lt;/p&gt;&lt;p&gt;&lt;/div&gt;&lt;/BLOCKQUOTE&gt;&lt;/p&gt;&lt;p&gt;Δυστηχώς δεν δουλεύει ακριβώς έτσι - πχ η php στα windows δεν έχει πλήρη υποστήριξη&amp;nbsp;Unicode σε αντιθεση με ένα Unix κουτί. Έτσι ο ίδιος κώδικας, μεταφερόμενος από το ένα κουτί στο άλλο, δεν φέρνει τα ίδια αποτελέσματα στην βάση.&lt;/p&gt;&lt;p&gt;Δεν αρκεί μόνο η βάση για να γράψεις ελληνικά, και σίγουρα δεν είναι&amp;nbsp;"πρόβλημα" του κακού SQL Server - τις περισσότερες φορές, ειδικά σε περιβάλλοντα που&amp;nbsp;ο κώδικας δεν κάνει compile - .asp sites, .php sites - παίζει ρόλο και το encoding των αρχείων που γράφεις τον κώδικα, η default κωδικοσελίδα του λογαριασμού που τρέχει το application, και άλλα πραγματάκια που "ανακατεύουν με&amp;nbsp;το δαχτυλάκι" τους την κατάσταση.&lt;/p&gt;&lt;p&gt;&amp;nbsp;&amp;nbsp; &lt;/p&gt;&lt;p&gt;George J.&lt;/p&gt;</description></item><item><title>Απ: ΕΦΑΡΜΟΓΗ ΜΕ SQL SERVER και πρόβλημα με ελληνικούς χαρακτήρες...</title><link>https://www.dotnetzone.gr:443/cs/forums/thread/72766.aspx</link><pubDate>Wed, 05 Jun 2013 23:44:31 GMT</pubDate><guid isPermaLink="false">2622095e-976c-431a-859e-16783ec7ecd7:72766</guid><dc:creator>Παναγιώτης Καναβός</dc:creator><slash:comments>0</slash:comments><comments>https://www.dotnetzone.gr:443/cs/forums/thread/72766.aspx</comments><wfw:commentRss>https://www.dotnetzone.gr:443/cs/forums/commentrss.aspx?SectionID=73&amp;PostID=72766</wfw:commentRss><description>&lt;p&gt;Τί εννοείς "Τοποθέτηση των πεδίων της βάσης στις φόρμες"? Πως διαβάζεις τα δεδομένα και κυρίως, πως τα γράφεις? Καταρχήν, για ποιά γλώσσα μιλάμε?&amp;nbsp;&lt;/p&gt;&lt;p&gt;Επιπλέον, το nvarchar(MAX) χρησιμοποιείται όταν θέλεις να αποθηκεύσεις πολύ μεγάλα κείμενα.&amp;nbsp;&lt;span style="font-size:10pt;"&gt;&amp;nbsp;&lt;/span&gt;&lt;span style="font-size:10pt;"&gt;To collation δεν έχει σημασία αν αποθηκεύεις Unicode. Προφανώς αυτά που στέλνεις στη βάση δεν είναι Unicode.&lt;/span&gt;&lt;/p&gt;&lt;p&gt;Δείξε τον κώδικα που χρησιμοποιείς για να γράψεις, μήπως βγει κάποια άκρη&amp;nbsp;&lt;/p&gt;</description></item><item><title>Απ: ΕΦΑΡΜΟΓΗ ΜΕ SQL SERVER και πρόβλημα με ελληνικούς χαρακτήρες...</title><link>https://www.dotnetzone.gr:443/cs/forums/thread/72761.aspx</link><pubDate>Wed, 05 Jun 2013 20:45:18 GMT</pubDate><guid isPermaLink="false">2622095e-976c-431a-859e-16783ec7ecd7:72761</guid><dc:creator>paolo75gr</dc:creator><slash:comments>0</slash:comments><comments>https://www.dotnetzone.gr:443/cs/forums/thread/72761.aspx</comments><wfw:commentRss>https://www.dotnetzone.gr:443/cs/forums/commentrss.aspx?SectionID=73&amp;PostID=72761</wfw:commentRss><description>&lt;p&gt;Καλημέρα σας ευχαριστώ όλους για τις απαντήσεις σας&lt;/p&gt;&lt;p&gt;θα κάνω μια αναφορά του σχεδιασμού της εφαρμογής που δημιούργησα για να δω που&amp;nbsp;&lt;/p&gt;&lt;p&gt;κάνω το λάθος.&lt;/p&gt;&lt;p&gt;1. Δημιουργία φορμών που θα κάτσει αργότερα η βάση&lt;/p&gt;&lt;p&gt;2. δημιουργία της βάσης με χαρακτηριστικά στο nvachar(MAX) με collation Greek_BIN στα παιδιά που θέλω να αναγνωρίζει τα ελληνικά (επώνυμο, όνομα, διεύθυνση, κτλ)&amp;nbsp;&lt;/p&gt;&lt;p&gt;3.τοποθέτηση των πεδίων της βάσης στις φόρμες&lt;/p&gt;&lt;p&gt;Λογικά θα έπρεπε να αναγνωρίζει τους ελληνικούς χαρακτήρες η βάση γνωρίζεται αν πρέπει εκτος απο κωδικά που πρέπει να γραφτεί, αν οι ρυθμίσεις που έχω κάνει είναι σωστές.&lt;/p&gt;</description></item><item><title>Απ: ΕΦΑΡΜΟΓΗ ΜΕ SQL SERVER και πρόβλημα με ελληνικούς χαρακτήρες...</title><link>https://www.dotnetzone.gr:443/cs/forums/thread/72758.aspx</link><pubDate>Wed, 05 Jun 2013 17:41:51 GMT</pubDate><guid isPermaLink="false">2622095e-976c-431a-859e-16783ec7ecd7:72758</guid><dc:creator>Παναγιώτης Καναβός</dc:creator><slash:comments>0</slash:comments><comments>https://www.dotnetzone.gr:443/cs/forums/thread/72758.aspx</comments><wfw:commentRss>https://www.dotnetzone.gr:443/cs/forums/commentrss.aspx?SectionID=73&amp;PostID=72758</wfw:commentRss><description>&lt;p&gt;Και πως στέλνεις τα string στη βάση? Αν φτιάχνεις το sql statement με το χέρι και θέτεις π.χ. SomeField ='ΑΒΓΔ' η τιμή θα περάσει ως ASCII. Για να περάσει ως Unicode θα πρέπει να γράψεις SomeField=N'ΑΒΓΔ'.&lt;/p&gt;
&lt;p&gt;Αυτό όμως είναι κακή λύση, γιατί τα sql statements με το χέρι σε αφήνουν ορθάνοιχτο σε sql injection attacks και είναι και πιο αργά. Για φαντάσου να βάλει κάποιος ως τιμή σε κάποιο πεδίο το &lt;i&gt;';DROP TABLE xxx;--&lt;/i&gt;&lt;span style="font-size:10pt;"&gt;&lt;i&gt;&amp;nbsp;&lt;/i&gt;.&amp;nbsp;&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;Είναι πολύ απλό να φτιάξεις ένα parameterized query, μάλιστα είναι ευκολότερο από το να φτιάξεις το statement με το χέρι. Υπάρχουν πολλά posts εδώ και αλλού που δείχνουν πως να το κάνεις. Δες π.χ. το &lt;a href="http://www.codinghorror.com/blog/2005/04/give-me-parameterized-sql-or-give-me-death.html"&gt;Give me parameterize SQL or give me death"&lt;/a&gt;. Αν έχεις δύο ή παραπάνω παραμέτρους να περάσεις είναι σίγουρα πολύ ευκολότερο.&lt;/p&gt;&lt;p&gt;&lt;span style="font-size:10pt;"&gt;Άλλο ένα πλεονέκτημα είναι ότι όταν περνάς αριθμητικές παραμέτρους δεν σε απασχολεί η μορφή της υποδιαστολής. Αν φτιάχνεις το statement με το χέρι όμως, πάντα θα πρέπει να φροντίσεις η υποδιαστολή να είναι αυτή που περιμένει η βάση - με άλλα λόγια κλάφτα.&lt;/span&gt;&lt;/p&gt;&lt;p&gt;&amp;nbsp;&lt;/p&gt;</description></item><item><title>Απ: ΕΦΑΡΜΟΓΗ ΜΕ SQL SERVER και πρόβλημα με ελληνικούς χαρακτήρες...</title><link>https://www.dotnetzone.gr:443/cs/forums/thread/72755.aspx</link><pubDate>Wed, 05 Jun 2013 07:20:21 GMT</pubDate><guid isPermaLink="false">2622095e-976c-431a-859e-16783ec7ecd7:72755</guid><dc:creator>paolo75gr</dc:creator><slash:comments>0</slash:comments><comments>https://www.dotnetzone.gr:443/cs/forums/thread/72755.aspx</comments><wfw:commentRss>https://www.dotnetzone.gr:443/cs/forums/commentrss.aspx?SectionID=73&amp;PostID=72755</wfw:commentRss><description>&lt;p&gt;Καλησπέρα και ευχαριστώ για το χρόνο σου&amp;nbsp;&lt;/p&gt;&lt;p&gt;στα παιδιά της βάσης όπου χρειάζεται έχω βάλει nvchar και όχι vchar το πρόβλημα παραμένει&lt;/p&gt;&lt;p&gt;πιθανότατα καθότι και άσχετος στο θέμα θα πρέπει να γίνει και κάποια αναβάθμιση της sql αλλά και παραμετροποίηση όπως λες . Μακάρι να μπορέσω να την κάνω να δουλέψει.&lt;/p&gt;&lt;p&gt;&amp;nbsp;&lt;/p&gt;</description></item><item><title>Απ: ΕΦΑΡΜΟΓΗ ΜΕ SQL SERVER και πρόβλημα με ελληνικούς χαρακτήρες...</title><link>https://www.dotnetzone.gr:443/cs/forums/thread/72752.aspx</link><pubDate>Wed, 05 Jun 2013 04:03:05 GMT</pubDate><guid isPermaLink="false">2622095e-976c-431a-859e-16783ec7ecd7:72752</guid><dc:creator>Παναγιώτης Καναβός</dc:creator><slash:comments>0</slash:comments><comments>https://www.dotnetzone.gr:443/cs/forums/thread/72752.aspx</comments><wfw:commentRss>https://www.dotnetzone.gr:443/cs/forums/commentrss.aspx?SectionID=73&amp;PostID=72752</wfw:commentRss><description>&lt;p&gt;Αυτό που λένε και τα προηγούμενα posts είναι ότι το λάθος είναι στην ίδια την εφαρμογή και όχι στον SQL Server ή σε κάποια παράμετρο. Έχεις ορίσει varchar αντί για nvarchar πεδία και αποθηκεύεις ASCII χαρακτήρες αντί για Unicode. Κατά πάσα πιθανότητα αντί να χρησιμοποιείς parameterized queries φτιάχνεις το SQL statement μέσα στον κώδικα με αποτέλεσμα τα δεδομένα να πηγαίνουν στον server ως ASCII. Τα ??? είναι το αποτέλεσμα όταν ο OLEDB Driver προσπαθεί να μετατρέψει κείμενο από ένα codepage σε άλλο και αποτυγχάνει.&lt;/p&gt;&lt;p&gt;&amp;nbsp;Η λύση είναι η ίδια όπως και στα προηγούμενα posts. Άλλαξε τον τύπο των πεδίων σε nvarchar, στείλε Unicode δεδομένα&lt;span style="font-size:10pt;"&gt;&amp;nbsp;και χρησιμοποίησε parameterized queries αντί για χειροποίητα sql statements. Ακόμα καλύτερα, χρησιμοποίησε κάποιο ORM το οποίο θα φροντίσει να φτιάξει τα κατάλληλα statements από μόνο του.&lt;/span&gt;&lt;/p&gt;&lt;p&gt;Επαναλαμβάνω, το πρόβλημα δεν οφείλεται στον SQL Server. Το ίδιο ακριβώς πρόβλημα θα είχες με οποιαδήποτε βάση, σε οποιοδήποτε λειτουργικό - είτε αυτό λέγεται SQL Server πάνω από Windows, είτε Oracle πάνω από Unix.&lt;/p&gt;&lt;p&gt;&amp;nbsp;&lt;/p&gt;</description></item><item><title>ΕΦΑΡΜΟΓΗ ΜΕ SQL SERVER και πρόβλημα με ελληνικούς χαρακτήρες...</title><link>https://www.dotnetzone.gr:443/cs/forums/thread/72747.aspx</link><pubDate>Tue, 04 Jun 2013 21:16:17 GMT</pubDate><guid isPermaLink="false">2622095e-976c-431a-859e-16783ec7ecd7:72747</guid><dc:creator>paolo75gr</dc:creator><slash:comments>0</slash:comments><comments>https://www.dotnetzone.gr:443/cs/forums/thread/72747.aspx</comments><wfw:commentRss>https://www.dotnetzone.gr:443/cs/forums/commentrss.aspx?SectionID=73&amp;PostID=72747</wfw:commentRss><description>&lt;p&gt;Καλησπέρα στην κοινότητα&lt;/p&gt;&lt;p&gt;Έχω ένα πρόβλημα έχω φτιάξει ένα πρόγραμμα με βάση δεδομένων σαν πελατολόγιο (λογιστής γάρ) με κωδικούς για το taxisnet και το ΙΚΑ&lt;/p&gt;&lt;p&gt;κάθε φόρα όμως που γράφω ένα όνομα στα ελληνικά αυτό μετά την αποθήκευση εμφανίζεται με ??????? .έχω δει προηγούμενα ποστ&lt;/p&gt;&lt;p&gt;αλλα επειδή είμαι αρχάριος στον προγραμματισμό κάποια παράμετρο έχω κάνει λάθος.&lt;/p&gt;&lt;p&gt;το προγραμματάκι αυτό θα εγκατασταθεί σε δυο διαφορετικούς υπολογιστές .&lt;/p&gt;&lt;p&gt;σε αυτούς τους υπολογιστές υπάρχει &amp;nbsp;SQLserver 2005 και &amp;nbsp;2008 λόγο των προγραμμάτων λογιστικής που χρησιμοποιώ .&lt;/p&gt;&lt;p&gt;σας ευχαριστώ για το χρόνο σας &lt;/p&gt;&lt;p&gt;και τις απαντήσεις σας.&amp;nbsp;&lt;/p&gt;</description></item></channel></rss>