python Sqlite3相关基本操作
1、连接数据库
1 import sqlite3 2 3 conn = sqlite3.connect('test.db')
2、创建表
1 import sqlite3 2 3 conn = sqlite3.connect('test.db') 4 print "Opened database successfully"; 5 c = conn.cursor() 6 c.execute('''CREATE TABLE COMPANY 7 (ID INT PRIMARY KEY NOT NULL, 8 NAME TEXT NOT NULL, 9 AGE INT NOT NULL, 10 ADDRESS CHAR(50), 11 SALARY REAL);''') 12 print "Table created successfully"; 13 conn.commit() 14 conn.close()
3、INSERT 操作
1 import sqlite3 2 3 conn = sqlite3.connect('test.db') 4 c = conn.cursor() 5 print "Opened database successfully"; 6 7 c.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \ 8 VALUES (1, 'Paul', 32, 'California', 20000.00 )"); 9 10 c.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \ 11 VALUES (2, 'Allen', 25, 'Texas', 15000.00 )"); 12 13 c.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \ 14 VALUES (3, 'Teddy', 23, 'Norway', 20000.00 )"); 15 16 c.execute("INSERT INTO COMPANY (ID,NAME,AGE,ADDRESS,SALARY) \ 17 VALUES (4, 'Mark', 25, 'Rich-Mond ', 65000.00 )"); 18 19 conn.commit() 20 print "Records created successfully"; 21 conn.close()
4、SELECT 操作
1 import sqlite3 2 3 conn = sqlite3.connect('test.db') 4 c = conn.cursor() 5 print "Opened database successfully"; 6 7 cursor = c.execute("SELECT id, name, address, salary from COMPANY") 8 for row in cursor: 9 print "ID = ", row[0] 10 print "NAME = ", row[1] 11 print "ADDRESS = ", row[2] 12 print "SALARY = ", row[3], "\n" 13 14 print "Operation done successfully"; 15 conn.close()
5、UPDATE 操作
1 import sqlite3 2 3 conn = sqlite3.connect('test.db') 4 c = conn.cursor() 5 print "Opened database successfully"; 6 7 c.execute("UPDATE COMPANY set SALARY = 25000.00 where ID=1") 8 conn.commit() 9 print "Total number of rows updated :", conn.total_changes 10 11 cursor = conn.execute("SELECT id, name, address, salary from COMPANY") 12 for row in cursor: 13 print "ID = ", row[0] 14 print "NAME = ", row[1] 15 print "ADDRESS = ", row[2] 16 print "SALARY = ", row[3], "\n" 17 18 print "Operation done successfully"; 19 conn.close()
6、DELETE 操作
import sqlite3 conn = sqlite3.connect('test.db') c = conn.cursor() print "Opened database successfully"; c.execute("DELETE from COMPANY where ID=2;") conn.commit() print "Total number of rows deleted :", conn.total_changes cursor = conn.execute("SELECT id, name, address, salary from COMPANY") for row in cursor: print "ID = ", row[0] print "NAME = ", row[1] print "ADDRESS = ", row[2] print "SALARY = ", row[3], "\n" print "Operation done successfully"; conn.close()
7、执行sql语句时的格式
执行SQL语句。 可以是参数化 SQL 语句(即,在 SQL 语句中使用占位符)。sqlite3
模块支持两种占位符:问号(qmark风格)和命名占位符(命名风格)。
示例如下:
1 import sqlite3 2 3 con = sqlite3.connect(":memory:") 4 cur = con.cursor() 5 cur.execute("create table people (name_last, age)") 6 7 who = "Yeltsin" 8 age = 72 9 10 # This is the qmark style: 11 cur.execute("insert into people values (?, ?)", (who, age)) 12 13 # And this is the named style: 14 cur.execute("select * from people where name_last=:who and age=:age", {"who": who, "age": age}) 15 16 print(cur.fetchone()) 17 18 con.close()
8、外键使用
1. sqlite3 默认为关闭外键限制的,如要打开,请执行如下命令:
1 PRAGMA FOREIGN_KEYS=ON;
2、外键创建:
1 create table parent_t 2 3 ( 4 parent_id INTEGER NOT NULL PRIMARY KEY, 5 parent_name TEXT 6 ); 7 8 create table child_t 9 ( 10 child_t INTEGER NOT NULL PRIMARY KEY, 11 child_name TEXT NOT NULL, 12 parent_id INTEGER NOT NULL, 13 FOREIGN KEY (parent_id) REFERENCES parent_t(parent_id) ON DELETE CASCADE ON UPDATE CASCADE 14 );
3、另一种创建方式:
1 create table parent_t 2 3 ( 4 parent_id INTEGER NOT NULL PRIMARY KEY, 5 parent_name TEXT 6 ); 7 8 create table child_t 9 ( 10 child_t INTEGER NOT NULL PRIMARY KEY, 11 child_name TEXT NOT NULL, 12 parent_id INTEGER NOT NULL, 13 parent_id INTEGER REFERENCES parent_t(parent_id) ON DELETE CASCADE ON UPDATE CASCADE 14 );
9、其他sql语句
1.SqLite判断表是否存在,如果存在则删除该表:
1 DROP TABLE IF EXISTS TableName
2.SqLite判断表是否存在,如果不存在则创建指定的表:
1 CREATE TABLE IF NOT EXISTS TableName( 2 Id INTEGER PRIMARY KEY AUTOINCREMENT, 3 Url VARCHAR( 150 ), 4 IsCrawled BOOLEAN NOT NULL, 5 CreatedOn DATETIME NOT NULL, 6 CrawledDate DATETIME 7 );