以下是一个示例代码,演示如何按类别统计图书数量,并将结果放入不同的表中:
import sqlite3
# 连接到数据库
conn = sqlite3.connect('books.db')
c = conn.cursor()
# 创建图书表
c.execute('''CREATE TABLE IF NOT EXISTS books
(id INTEGER PRIMARY KEY AUTOINCREMENT,
title TEXT,
category TEXT)''')
# 插入示例数据
books = [('Book 1', 'Fiction'),
('Book 2', 'Fiction'),
('Book 3', 'Non-fiction'),
('Book 4', 'Non-fiction'),
('Book 5', 'Fiction')]
c.executemany('INSERT INTO books (title, category) VALUES (?, ?)', books)
# 创建统计结果表
c.execute('''CREATE TABLE IF NOT EXISTS book_counts
(category TEXT,
count INTEGER)''')
# 统计图书数量并插入结果表
c.execute('''INSERT INTO book_counts
SELECT category, COUNT(*) FROM books
GROUP BY category''')
# 提交更改并关闭连接
conn.commit()
conn.close()
上述代码使用SQLite数据库连接到名为books.db
的数据库。首先,它创建一个名为books
的表,其中包含id
,title
和category
列。然后,它插入一些示例图书数据。
接下来,代码创建一个名为book_counts
的表,其中包含category
和count
列,用于存储按类别统计的结果。最后,它执行一个SELECT
语句来统计图书数量,并使用INSERT INTO
语句将结果插入book_counts
表中。
请注意,这只是一个示例,实际情况可能需要根据具体需求进行修改。另外,示例代码使用SQLite数据库,如果使用其他数据库,可能需要相应地更改代码。
上一篇:按类别填充缺失日期