Latest web development tutorials

SQLite - Python

installer

Le module SQLite3 de peut être utilisé avec l'intégration Python. Module sqlite3 écrit par Gerhard Haring. Il fournit une spécification API DB-2.0 décrit par le PEP 249 est compatible avec l'interface SQL. Vous ne devez pas installer le module séparément, parce que Python 2.5.x ou par défaut plus tard est livré avec le module.

Pour utiliser le module sqlite3, vous devez d'abord créer une représentation de l'objet de connexion de base de données, et vous pouvez choisir de créer un objet curseur, qui vous aidera à effectuer toutes les instructions SQL.

Module de l'API Python

Le programme important du module sqlite3 suivants sont pour répondre à vos besoins en utilisant la base de données SQLite dans les programmes Python. Si vous avez besoin de plus de détails, voir le module officiel sqlite3 documentation Python.

序号API & 描述
1sqlite3.connect(database [,timeout ,other optional arguments])

该 API 打开一个到 SQLite 数据库文件 database 的链接。您可以使用 ":memory:" 来在 RAM 中打开一个到 database 的数据库连接,而不是在磁盘上打开。如果数据库成功打开,则返回一个连接对象。

当一个数据库被多个连接访问,且其中一个修改了数据库,此时 SQLite 数据库被锁定,直到事务提交。timeout 参数表示连接等待锁定的持续时间,直到发生异常断开连接。timeout 参数默认是 5.0(5 秒)。

如果给定的数据库名称 filename 不存在,则该调用将创建一个数据库。如果您不想在当前目录中创建数据库,那么您可以指定带有路径的文件名,这样您就能在任意地方创建数据库。

2connection.cursor([cursorClass])

该例程创建一个cursor,将在 Python 数据库编程中用到。该方法接受一个单一的可选的参数 cursorClass。如果提供了该参数,则它必须是一个扩展自 sqlite3.Cursor 的自定义的 cursor 类。

3cursor.execute(sql [, optional parameters])

该例程执行一个 SQL 语句。该 SQL 语句可以被参数化(即使用占位符代替 SQL 文本)。sqlite3 模块支持两种类型的占位符:问号和命名占位符(命名样式)。

例如:cursor.execute("insert into people values (?, ?)", (who, age))

4connection.execute(sql [, optional parameters])

该例程是上面执行的由光标(cursor)对象提供的方法的快捷方式,它通过调用光标(cursor)方法创建了一个中间的光标对象,然后通过给定的参数调用光标的 execute 方法。

5cursor.executemany(sql, seq_of_parameters)

该例程对 seq_of_parameters 中的所有参数或映射执行一个 SQL 命令。

6connection.executemany(sql[, parameters])

该例程是一个由调用光标(cursor)方法创建的中间的光标对象的快捷方式,然后通过给定的参数调用光标的 executemany 方法。

7cursor.executescript(sql_script)

该例程一旦接收到脚本,会执行多个 SQL 语句。它首先执行 COMMIT 语句,然后执行作为参数传入的 SQL 脚本。所有的 SQL 语句应该用分号(;)分隔。

8connection.executescript(sql_script)

该例程是一个由调用光标(cursor)方法创建的中间的光标对象的快捷方式,然后通过给定的参数调用光标的 executescript 方法。

9connection.total_changes()

该例程返回自数据库连接打开以来被修改、插入或删除的数据库总行数。

10connection.commit()

该方法提交当前的事务。如果您未调用该方法,那么自您上一次调用 commit() 以来所做的任何动作对其他数据库连接来说是不可见的。

11connection.rollback()

该方法回滚自上一次调用 commit() 以来对数据库所做的更改。

12connection.close()

该方法关闭数据库连接。请注意,这不会自动调用 commit()。如果您之前未调用 commit() 方法,就直接关闭数据库连接,您所做的所有更改将全部丢失!

13cursor.fetchone()

该方法获取查询结果集中的下一行,返回一个单一的序列,当没有更多可用的数据时,则返回 None。

14cursor.fetchmany([size=cursor.arraysize])

该方法获取查询结果集中的下一行组,返回一个列表。当没有更多的可用的行时,则返回一个空的列表。该方法尝试获取由 size 参数指定的尽可能多的行。

15cursor.fetchall()

该例程获取查询结果集中所有(剩余)的行,返回一个列表。当没有可用的行时,则返回一个空的列表。

Connectez-vous à la base de données

Le code Python suivant montre comment se connecter à une base de données existante. Si la base de données n'existe pas, il est créé, et enfin retourne un objet de base de données.

#! / Usr / bin / python

sqlite3 d'importation

conn = sqlite3.connect ( 'test.db')

print "Ouvert base de données avec succès";

Ici, vous pouvez également copier le nom de la base de données pour unnom spécifique: mémoire :, Cela va créer une base de données dans la RAM.Maintenant, nous allons exécuter le programme ci - dessus, créez notretest.db de base de données dans le répertoire courant.Vous pouvez modifier le chemin si nécessaire. Enregistrez le code ci-dessus pour sqlite.py fichier et appuyez montré est effectuée comme suit. Si la base de données est créé avec succès, il affiche le message ci-dessous:

$ Chmod + x sqlite.py
$. / Sqlite.py
Ouvrez la base de données avec succès

Créer une table

Le code Python suivant sera utilisé pour créer une table dans la base de données créée précédemment:

#! / Usr / bin / python

sqlite3 d'importation

conn = sqlite3.connect ( 'test.db')
print "Ouvert base de données avec succès";

conn.Execute ( '' 'CREATE TABLE COMPANY
       (ID INT PRIMARY KEY NOT NULL,
       NOM TEXT NOT NULL,
       AGE INT NOT NULL,
       ADRESSE CHAR (50),
       SALAIRE RÉEL); '' ')
print "Table créée avec succès";

conn.close ()

Lorsque la procédure ci - dessus, il crée la table de l' entreprise danstest.db et affiche le message ci - dessous:

base de données ouvert avec succès
Tableau créé avec succès

opération INSERT

Le programme Python suivant montre comment créer des enregistrements dans la table de société créée ci-dessus:

#! / Usr / bin / python

sqlite3 d'importation

conn = sqlite3.connect ( 'test.db')
print "Ouvert base de données avec succès";

conn.Execute ( "INSERT INTO COMPANY (ID, nom, âge, adresse, SALAIRE) \
      VALUES (1, 'Paul', 32, 'California', 20000.00) ");

conn.Execute ( "INSERT INTO COMPANY (ID, nom, âge, adresse, SALAIRE) \
      VALUES (2, 'Allen', 25, 'Texas', 15000.00) ");

conn.Execute ( "INSERT INTO COMPANY (ID, nom, âge, adresse, SALAIRE) \
      VALEURS (3, 'Teddy', 23, «Norvège», 20000.00) ");

conn.Execute ( "INSERT INTO COMPANY (ID, nom, âge, adresse, SALAIRE) \
      VALEURS (4, 'Mark', 25, 'Rich-Mond', 65000.00) ");

conn.commit ()
print "dossiers créés avec succès";
conn.close ()

Le programme ci-dessus est exécuté, il sera créé dans le tableau de la société pour un enregistrement donné, et affiche les deux lignes suivantes:

base de données ouvert avec succès
Dossiers créé avec succès

opérations SELECT

Le programme Python suivant montre comment obtenir de la table de société créée plus tôt et affiche l'enregistrement:

#! / Usr / bin / python

sqlite3 d'importation

conn = sqlite3.connect ( 'test.db')
print "Ouvert base de données avec succès";

curseur = conn.Execute ( "SELECT id, nom, adresse, salaire de SOCIÉTÉ»)
pour la ligne de curseur:
   print "ID =", ligne [0]
   print "NAME =", ligne [1]
   print "ADDRESS =", ligne [2]
   print "SALAIRE =", ligne [3], "\ n"

print "Opération effectuée avec succès";
conn.close ()

Lorsque le programme ci-dessus est exécuté, il va produire les résultats suivants:

base de données ouvert avec succès
ID = 1
NAME = Paul
ADDRESS = Californie
SALAIRE = 20000.0

ID = 2
NAME = Allen
ADDRESS = Texas
SALAIRE = 15000.0

ID = 3
NAME = Teddy
ADDRESS = Norvège
SALAIRE = 20000.0

ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALAIRE = 65000,0

Opération effectuée avec succès

opération UPDATE

Le code Python suivant montre comment utiliser l'instruction UPDATE pour mettre à jour tous les dossiers, puis obtenir à partir du tableau de l'entreprise et afficher l'enregistrement mis à jour:

#! / Usr / bin / python

sqlite3 d'importation

conn = sqlite3.connect ( 'test.db')
print "Ouvert base de données avec succès";

conn.Execute ( "ENTREPRISE UPDATE définie SALAIRE = 25000.00 où ID = 1")
conn.commit
imprimer "Nombre total de lignes mises à jour:", conn.total_changes

curseur = conn.Execute ( "SELECT id, nom, adresse, salaire de SOCIÉTÉ»)
pour la ligne de curseur:
   print "ID =", ligne [0]
   print "NAME =", ligne [1]
   print "ADDRESS =", ligne [2]
   print "SALAIRE =", ligne [3], "\ n"

print "Opération effectuée avec succès";
conn.close ()

Lorsque le programme ci-dessus est exécuté, il va produire les résultats suivants:

base de données ouvert avec succès
Nombre total de lignes mises à jour: 1
ID = 1
NAME = Paul
ADDRESS = Californie
SALAIRE = 25000,0

ID = 2
NAME = Allen
ADDRESS = Texas
SALAIRE = 15000.0

ID = 3
NAME = Teddy
ADDRESS = Norvège
SALAIRE = 20000.0

ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALAIRE = 65000,0

Opération effectuée avec succès

opération DELETE

Le code Python suivant montre comment utiliser l'instruction DELETE supprime tous les enregistrements, puis repris dans le tableau de l'entreprise et affiche l'enregistrement restant:

#! / Usr / bin / python

sqlite3 d'importation

conn = sqlite3.connect ( 'test.db')
print "Ouvert base de données avec succès";

conn.Execute ( "DELETE d'entreprise où ID = 2;")
conn.commit
print "Nombre total de lignes supprimées:", conn.total_changes

curseur = conn.Execute ( "SELECT id, nom, adresse, salaire de SOCIÉTÉ»)
pour la ligne de curseur:
   print "ID =", ligne [0]
   print "NAME =", ligne [1]
   print "ADDRESS =", ligne [2]
   print "SALAIRE =", ligne [3], "\ n"

print "Opération effectuée avec succès";
conn.close ()

Lorsque le programme ci-dessus est exécuté, il va produire les résultats suivants:

base de données ouvert avec succès
Nombre total de lignes supprimées: 1
ID = 1
NAME = Paul
ADDRESS = Californie
SALAIRE = 20000.0

ID = 3
NAME = Teddy
ADDRESS = Norvège
SALAIRE = 20000.0

ID = 4
NAME = Mark
ADDRESS = Rich-Mond
SALAIRE = 65000,0

Opération effectuée avec succès