<?xml version="1.0" encoding="UTF-8"?><rss xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:atom="http://www.w3.org/2005/Atom" version="2.0"><channel><title><![CDATA[[Tutoriel] Commencer à utiliser SQLite avec C#]]></title><description><![CDATA[<p dir="auto">Bonjour, bonsoir !<br />
 <br />
Aujourd'hui nous allons apprendre à utiliser <strong>SQLite</strong> en <strong>C#</strong>, pour cela je divise le tutoriel en trois grandes parties :<br />
 <br />
I • SQLite, c'est quoi ?<br />
II • Pour quelles utilisations ?<br />
III • Utiliser SQLite<br />
 <br />
<strong>I • SQLite, c'est quoi ?</strong><br />
 <br />
<strong>SQLite</strong> est une bibliothèque écrite en C qui propose un moteur de base de données relationnelle accessible par le langage <strong>SQL</strong>. <strong>SQLite</strong> implémente en grande partie le standard SQL-92 et des propriétés ACID.<br />
 <br />
Contrairement aux serveurs de bases de données traditionnels, comme <strong>MySQL</strong> ou <strong>PostgreSQL</strong>, sa particularité est de ne pas reproduire le schéma habituel client-serveur mais d'être directement intégrée aux programmes. L'intégralité de la base de données (déclarations, tables, index et données) est stockée dans un fichier indépendant de la plateforme.<br />
 <br />
<strong>D. Richard Hipp</strong>, le créateur de <strong>SQLite</strong>, a choisi de mettre cette bibliothèque ainsi que son code source dans le domaine public, ce qui permet son utilisation sans restriction aussi bien dans les projets open source que dans les projets propriétaires. Le créateur ainsi qu'une partie des développeurs principaux de <strong>SQLite</strong> sont employés par la société américaine <strong>Hwaci</strong>.<br />
 <br />
 <br />
<strong>SQLite</strong> est le moteur de base de données le plus distribué au monde, grâce à son utilisation dans de nombreux logiciels grand public comme <strong>Firefox</strong>, <strong>Skype</strong>, <strong>Google Gears</strong>, dans certains produits d'<strong>Apple</strong>, d'<strong>Adobe</strong> et de <strong>McAfee</strong> et dans les bibliothèques standards de nombreux langages comme <strong>PHP</strong> ou <strong>Python</strong>. De par son extrême légèreté (moins de 300 Kio), il est également très populaire sur les systèmes embarqués, notamment sur la plupart des smartphones modernes : l'<strong>iPhone</strong> ainsi que les systèmes d'exploitation mobiles <strong>Symbian</strong> et <strong>Android</strong> l'utilisent comme base de données embarquée. Au total, on peut dénombrer plus d'un milliard de copies connues et déclarées de la bibliothèque.<br />
 <br />
(Source : Wikipedia)<br />
 <br />
Nous allons aujourd'hui nous intéresser au wrapper .Net de <strong>SQLite</strong>.<br />
 <br />
 <br />
<strong>II • Pour quels utilisations ?</strong><br />
 <br />
Comme dit plus haut, <strong>SQLite</strong> permet d'accéder à une <strong>base de données</strong> uniquement en <strong>local</strong>, depuis un fichier, ce qui limite donc les utilisations. Vous pourrez utiliser cette librairie donc pour des projets locaux comme par exemple gérer un système de compte sur une seule machine, stocker des résultats de calculs ou encore stocker des scores pour un jeu solo... Cependant utiliser <strong>SQLite</strong> pour des jeux ou applications diverses en ligne n'est pas possible directement, il va falloir passer par un serveur.<br />
 <br />
Des connaissances sur le SQL sont fortement recommandées, si vous n'y connaissez rien, allez lire le tutoriel sur OpenClassRoom ou sur n'importe quel autre site.<br />
 <br />
<strong>III • Utiliser SQLite</strong><br />
 <br />
<strong>Importer la librairie</strong><br />
 <br />
Premièrement il va vous falloir la librairie, télécharger là ici : <a href="http://www.mediafire.com/download/53kb0zwdkw5od7o/System.Data.SQLite.dll" rel="nofollow ugc">System.Data.SQLite.dll</a><br />
 <br />
Une fois votre projet crée sous <strong>Visual Studio</strong>, importer cette librairie à votre celui-ci, pour cela, clic droit sur le projet puis "Importer une référence".<br />
Pour finir l'importation ajoutez ceci au début de la classe où vous voulez utiliser <strong>SQLite</strong> :</p>
<pre><code>using System.Data.SQLite;
</code></pre>
<p dir="auto"><strong>Créer un fichier de base de données</strong><br />
 <br />
Chaque base de données aura son propre fichier, pour créer un fichier de base de données, nous allons utiliser la méthode statique <strong>CreateFile</strong> contenue dans la classe <strong>SQLiteConnection</strong> :</p>
<pre><code>SQLiteConnection.CreateFile("MaBaseDeDonnees.sqlite");
</code></pre>
<p dir="auto">J'utilise ici l'extention .sqlite, mais vous pouvez mettre ce que vous voulez ! (.db, .blabla)<br />
 <br />
<strong>Connexion à la base de données</strong><br />
 <br />
Avant de pouvoir utiliser cette base de données, il va falloir se connecter à celle-ci, pour cela nous allons déclarer une nouvelle <strong>SQLiteConnection</strong> :</p>
<pre><code>SQLiteConnection maConnexion;
</code></pre>
<p dir="auto">Puis l'instancier et ouvrir la connexion :</p>
<pre><code>maConnexion= new SQLiteConnection("Data Source=MaBaseDeDonnees.sqlite;Version=3;");
maConnexion.Open();
</code></pre>
<p dir="auto">Pour fermer la connexion :</p>
<pre><code>MaBaseDeDonnees.Close();
</code></pre>
<p dir="auto">N'oubliez pas de la fermer une fois que vous n'en avez plus besoin <img src="http://new.melinyel.net/assets/plugins/nodebb-plugin-emoji/emoji/android/1f609.png?v=aa95655114f" class="not-responsive emoji emoji-android emoji--wink" style="height:23px;width:auto;vertical-align:middle" title=";)" alt="😉" /></p>
<p dir="auto"><strong>Créer une table</strong></p>
<p dir="auto">Désormais nous allons utiliser le <strong>SQL</strong>, nous allons créer une table qui contiendra les meilleurs scores pour un jeu, donc un nom de type "text" et un score de type "int" :</p>
<pre><code>string sql = "create table meilleursscores (nom text, score int)";
</code></pre>
<p dir="auto">Nous devons créer un objet de type <strong>SQLiteCommand</strong> pour pouvoir l'éxécuter :</p>
<pre><code>SQLiteCommand commande = new SQLiteCommand(sql, maConnexion);
</code></pre>
<p dir="auto">Puis nous allons éxecuter cette commande :</p>
<pre><code>command.ExecuteNonQuery();
</code></pre>
<p dir="auto"><strong>Remplir la table</strong></p>
<p dir="auto">Nous allons maintenant remplir cette table comme ceci :</p>
<pre><code>string sql = "insert into meilleursscores (nom, score) values ('VFRZ', 100)";
SQLiteCommand commande = new SQLiteCommand(sql, maConnexion);
commande.ExecuteNonQuery();
</code></pre>
<p dir="auto"><strong>Lire les meilleurs scores depuis la table</strong></p>
<p dir="auto">Pour lire la table c'est un peu différent que pour la remplir ou la créer.</p>
<p dir="auto">Premièrement, la commande select :</p>
<pre><code>string sql = "select * from meilleursscores order by score desc";
SQLiteCommand commande = new SQLiteCommand(sql, maConnexion);
</code></pre>
<p dir="auto">Puis il va falloir utiliser un <strong>SQLiteDataReader</strong> pour utiliser cette commande :</p>
<pre><code>SQLiteDataReader reader = command.ExecuteReader();
while (reader.Read())
       Console.WriteLine("Nom: " + reader["nom"] + "\tScore: " + reader["score"]);
</code></pre>
<p dir="auto">J'espère que ce tutoriel vous a été utile !</p>
<p dir="auto">N'hésitez pas à poser des questions.</p>
<p dir="auto">VFRZ</p>
]]></description><link>http://new.melinyel.net/topic/1700/tutoriel-commencer-à-utiliser-sqlite-avec-c</link><generator>RSS for Node</generator><lastBuildDate>Thu, 21 May 2026 19:32:31 GMT</lastBuildDate><atom:link href="http://new.melinyel.net/topic/1700.rss" rel="self" type="application/rss+xml"/><pubDate>Tue, 28 Jul 2015 21:03:05 GMT</pubDate><ttl>60</ttl><item><title><![CDATA[Reply to [Tutoriel] Commencer à utiliser SQLite avec C# on Mon, 17 Oct 2016 19:44:18 GMT]]></title><description><![CDATA[<p dir="auto">Ok je vais aller voir sur openclassroom.</p>
<p dir="auto">Merci quand même.</p>
]]></description><link>http://new.melinyel.net/post/17929</link><guid isPermaLink="true">http://new.melinyel.net/post/17929</guid><dc:creator><![CDATA[neconu]]></dc:creator><pubDate>Mon, 17 Oct 2016 19:44:18 GMT</pubDate></item><item><title><![CDATA[Reply to [Tutoriel] Commencer à utiliser SQLite avec C# on Mon, 17 Oct 2016 19:25:26 GMT]]></title><description><![CDATA[<p dir="auto">Désolé si je me trompe mais tu donnes réellement l'impression que tu ne comprends même pas le code que tu as donné...</p>
<p dir="auto">Bon en gros, tu fais exactement la même chose que dans ce code sauf qu'au lieu d'afficher les éléments avec "Console.WriteLine", tu les ajoutes à la textbox comme dit dans mon message précédent.</p>
<p dir="auto">Ps : Si tu débutes en C# ne cherche pas à faire des choses comme ca si tu ne comprends pas, commence par lire des guides (livres, vidéos, openclassrooms).</p>
]]></description><link>http://new.melinyel.net/post/17928</link><guid isPermaLink="true">http://new.melinyel.net/post/17928</guid><dc:creator><![CDATA[vfrz]]></dc:creator><pubDate>Mon, 17 Oct 2016 19:25:26 GMT</pubDate></item><item><title><![CDATA[Reply to [Tutoriel] Commencer à utiliser SQLite avec C# on Mon, 17 Oct 2016 18:47:36 GMT]]></title><description><![CDATA[<p dir="auto">Bonsoir et merci de m'accorder du temps.</p>
<p dir="auto">Je voudrais adapter ce code pour faire afficher le contenu de la bdd dans un listbox.</p>
<p dir="auto">Et ça je ne trouve pas comment faire....</p>
<p dir="auto">En mode console le code fonctionne bien, mais pas dans une windows form.</p>
<p dir="auto">Cordialement.</p>
]]></description><link>http://new.melinyel.net/post/17927</link><guid isPermaLink="true">http://new.melinyel.net/post/17927</guid><dc:creator><![CDATA[neconu]]></dc:creator><pubDate>Mon, 17 Oct 2016 18:47:36 GMT</pubDate></item><item><title><![CDATA[Reply to [Tutoriel] Commencer à utiliser SQLite avec C# on Mon, 17 Oct 2016 16:39:57 GMT]]></title><description><![CDATA[<p dir="auto">Salut,</p>
<p dir="auto">désolé pour le délai de réponse je suis beaucoup occupé en ce moment.</p>
<p dir="auto">Que veux tu dire que tu n'arrives pas à "l'adpter" ? Tu ne sais pas ajouter des éléments dans une listbox ?</p>
<p dir="auto">Si c'est le cas tu as juste à faire ceci :</p>
<pre><code>listbox.Items.Add("Hello world");
</code></pre>
<p dir="auto">Sinon décris ton problème plus précisement <img src="http://new.melinyel.net/assets/plugins/nodebb-plugin-emoji/emoji/android/1f609.png?v=aa95655114f" class="not-responsive emoji emoji-android emoji--wink" style="height:23px;width:auto;vertical-align:middle" title=";)" alt="😉" /></p>
]]></description><link>http://new.melinyel.net/post/17926</link><guid isPermaLink="true">http://new.melinyel.net/post/17926</guid><dc:creator><![CDATA[vfrz]]></dc:creator><pubDate>Mon, 17 Oct 2016 16:39:57 GMT</pubDate></item><item><title><![CDATA[Reply to [Tutoriel] Commencer à utiliser SQLite avec C# on Mon, 17 Oct 2016 10:05:15 GMT]]></title><description><![CDATA[<p dir="auto">Personne ?</p>
]]></description><link>http://new.melinyel.net/post/17925</link><guid isPermaLink="true">http://new.melinyel.net/post/17925</guid><dc:creator><![CDATA[neconu]]></dc:creator><pubDate>Mon, 17 Oct 2016 10:05:15 GMT</pubDate></item><item><title><![CDATA[Reply to [Tutoriel] Commencer à utiliser SQLite avec C# on Sat, 15 Oct 2016 16:59:45 GMT]]></title><description><![CDATA[<p dir="auto">Bonjour,</p>
<p dir="auto">Je suis débutant en C# et je cherche quelques renseignements sur ce code trouvé sur le web :</p>
<pre><code>namespace SQLiteSamples
{
    class Program
    {
        // Maintient la connexion
        SQLiteConnection m_dbConnection;

        static void Main(string[] args)
        {
            Program p = new Program();
        }

        public Program()
        {
            connectToDatabase();
            printConsole();
        }

        // Creates a connection with our database file.
        void connectToDatabase()
        {
            m_dbConnection = new SQLiteConnection("Data Source=login.sqlite;Version=3;");
            m_dbConnection.Open();
        }

        // Affiche les noms et login dans la console
        void printConsole()
        {
            string sql = "select * from MYDATA order by Nom desc";
            SQLiteCommand command = new SQLiteCommand(sql, m_dbConnection);
            SQLiteDataReader reader = command.ExecuteReader();
            while (reader.Read())
                Console.WriteLine("Nom: " + reader["Nom"] + " Login: " + reader["Login"]);
            Console.ReadLine();
        }
    }
}
</code></pre>
<p dir="auto">Je n'arrive pas à l'adapter dans une window form pour qu'il s'affiche dans une list box.</p>
<p dir="auto">Merci pour votre aide.</p>
<p dir="auto">Cordialement.</p>
]]></description><link>http://new.melinyel.net/post/17923</link><guid isPermaLink="true">http://new.melinyel.net/post/17923</guid><dc:creator><![CDATA[neconu]]></dc:creator><pubDate>Sat, 15 Oct 2016 16:59:45 GMT</pubDate></item><item><title><![CDATA[Reply to [Tutoriel] Commencer à utiliser SQLite avec C# on Wed, 29 Jul 2015 09:33:06 GMT]]></title><description><![CDATA[<p dir="auto">Merci pour ce tuto  <img src="http://new.melinyel.net/assets/plugins/nodebb-plugin-emoji/emoji/android/1f642.png?v=aa95655114f" class="not-responsive emoji emoji-android emoji--slightly_smiling_face" style="height:23px;width:auto;vertical-align:middle" title=":)" alt="🙂" /></p>
]]></description><link>http://new.melinyel.net/post/16906</link><guid isPermaLink="true">http://new.melinyel.net/post/16906</guid><dc:creator><![CDATA[Akimace]]></dc:creator><pubDate>Wed, 29 Jul 2015 09:33:06 GMT</pubDate></item><item><title><![CDATA[Reply to [Tutoriel] Commencer à utiliser SQLite avec C# on Wed, 29 Jul 2015 07:51:09 GMT]]></title><description><![CDATA[<blockquote>
<p dir="auto">C'est un langage haut niveau, c'est plus facile que le C/C++ ? Il faudrait que je m'y intéresse car ça à l'air d'etre quelque chose que je pourrais maitriser ^^</p>
</blockquote>
<p dir="auto">Oui c'est plus simple, le c# ressemble beaucoup au Java, mais personnellement je le trouve mieux que le java pour plusieurs raisons: les threads, la création de Gui/Windows, le réseau... Je ferais un post aussi avec quelques guides et tutoriels <img src="http://new.melinyel.net/assets/plugins/nodebb-plugin-emoji/emoji/android/1f609.png?v=aa95655114f" class="not-responsive emoji emoji-android emoji--wink" style="height:23px;width:auto;vertical-align:middle" title=";)" alt="😉" /></p>
]]></description><link>http://new.melinyel.net/post/16898</link><guid isPermaLink="true">http://new.melinyel.net/post/16898</guid><dc:creator><![CDATA[vfrz]]></dc:creator><pubDate>Wed, 29 Jul 2015 07:51:09 GMT</pubDate></item><item><title><![CDATA[Reply to [Tutoriel] Commencer à utiliser SQLite avec C# on Wed, 29 Jul 2015 05:50:47 GMT]]></title><description><![CDATA[<p dir="auto">Si j'ai le temps, je ferai une présentation générale du langage C# dans la journée ou demain pour les novices <img src="http://new.melinyel.net/assets/plugins/nodebb-plugin-emoji/emoji/android/1f609.png?v=aa95655114f" class="not-responsive emoji emoji-android emoji--wink" style="height:23px;width:auto;vertical-align:middle" title=";)" alt="😉" /></p>
]]></description><link>http://new.melinyel.net/post/16897</link><guid isPermaLink="true">http://new.melinyel.net/post/16897</guid><dc:creator><![CDATA[Pirkoa]]></dc:creator><pubDate>Wed, 29 Jul 2015 05:50:47 GMT</pubDate></item><item><title><![CDATA[Reply to [Tutoriel] Commencer à utiliser SQLite avec C# on Wed, 29 Jul 2015 00:53:57 GMT]]></title><description><![CDATA[<p dir="auto">C'est un langage haut niveau, c'est plus facile que le C/C++ ? Il faudrait que je m'y intéresse car ça à l'air d'etre quelque chose que je pourrais maitriser ^^</p>
]]></description><link>http://new.melinyel.net/post/16895</link><guid isPermaLink="true">http://new.melinyel.net/post/16895</guid><dc:creator><![CDATA[Soulalex]]></dc:creator><pubDate>Wed, 29 Jul 2015 00:53:57 GMT</pubDate></item><item><title><![CDATA[Reply to [Tutoriel] Commencer à utiliser SQLite avec C# on Wed, 29 Jul 2015 00:32:55 GMT]]></title><description><![CDATA[<p dir="auto">Merci pour ce jooli tuto ! <img src="http://new.melinyel.net/assets/plugins/nodebb-plugin-emoji/emoji/android/1f604.png?v=aa95655114f" class="not-responsive emoji emoji-android emoji--smile" style="height:23px;width:auto;vertical-align:middle" title=":D" alt="😄" /></p>
<p dir="auto">C#, c'est le bien <img src="http://new.melinyel.net/assets/plugins/nodebb-plugin-emoji/emoji/android/1f642.png?v=aa95655114f" class="not-responsive emoji emoji-android emoji--slightly_smiling_face" style="height:23px;width:auto;vertical-align:middle" title=":)" alt="🙂" /></p>
]]></description><link>http://new.melinyel.net/post/16892</link><guid isPermaLink="true">http://new.melinyel.net/post/16892</guid><dc:creator><![CDATA[Pirkoa]]></dc:creator><pubDate>Wed, 29 Jul 2015 00:32:55 GMT</pubDate></item><item><title><![CDATA[Reply to [Tutoriel] Commencer à utiliser SQLite avec C# on Wed, 29 Jul 2015 00:08:09 GMT]]></title><description><![CDATA[<p dir="auto">Plein de choses ! Des applications consoles, des logiciels divers, des applications Windows Phone voir Android. Des jeux avec Unity ou encore xna. Pour moi c'est un très bon langage, seul petit défaut c'est que de base, il est uniquement compatible sur Windows, même si aujourd'hui grâce à Mono on peut faire du c# pour Mac, Linux...</p>
]]></description><link>http://new.melinyel.net/post/16891</link><guid isPermaLink="true">http://new.melinyel.net/post/16891</guid><dc:creator><![CDATA[vfrz]]></dc:creator><pubDate>Wed, 29 Jul 2015 00:08:09 GMT</pubDate></item><item><title><![CDATA[Reply to [Tutoriel] Commencer à utiliser SQLite avec C# on Tue, 28 Jul 2015 22:33:21 GMT]]></title><description><![CDATA[<p dir="auto">Merci pour ce tutoriel d'une grande qualité <img src="http://new.melinyel.net/assets/plugins/nodebb-plugin-emoji/emoji/android/1f642.png?v=aa95655114f" class="not-responsive emoji emoji-android emoji--slightly_smiling_face" style="height:23px;width:auto;vertical-align:middle" title=":)" alt="🙂" /></p>
<p dir="auto">Je ne me suis jamais intéressé au C# mais qu'est ce qu'on peut faire exactement avec ?</p>
]]></description><link>http://new.melinyel.net/post/16889</link><guid isPermaLink="true">http://new.melinyel.net/post/16889</guid><dc:creator><![CDATA[Soulalex]]></dc:creator><pubDate>Tue, 28 Jul 2015 22:33:21 GMT</pubDate></item></channel></rss>