一文带你了解三大开源关系型数据库:SQLite、MySQL和PostgreSQL
SQLite:
SQLite是一个开源的嵌入式数据库,实现了多数SQL标准。它通常作为一个自包含在单个文件中的数据库,被用于简单的应用。
import sqlite3
# 连接到SQLite数据库
# 数据库文件是test.db,如果文件不存在,会自动在当前目录创建:
conn = sqlite3.connect('test.db')
# 创建一个Cursor:
cursor = conn.cursor()
# 执行一条SQL语句,创建user表:
cursor.execute('CREATE TABLE IF NOT EXISTS user (id VARCHAR(20) PRIMARY KEY, name VARCHAR(20))')
# 关闭Cursor:
cursor.close()
# 提交事务:
conn.commit()
# 关闭Connection:
conn.close()
MySQL:
MySQL是一个开源的关系型数据库管理系统,也是最流行的开源数据库之一。
import mysql.connector
# 连接到MySQL数据库
conn = mysql.connector.connect(user='username', password='password', host='hostname', database='databasename')
# 创建一个Cursor:
cursor = conn.cursor()
# 执行一条SQL语句,创建表:
cursor.execute('CREATE TABLE IF NOT EXISTS user (id INT PRIMARY KEY, name VARCHAR(20))')
# 关闭Cursor:
cursor.close()
# 提交事务:
conn.commit()
# 关闭Connection:
conn.close()
PostgreSQL:
PostgreSQL是一个功能强大的开源对象-关系型数据库系统,提供了很多其他商业数据库系统的功能,并且它是开源的。
import psycopg2
# 连接到PostgreSQL数据库
conn = psycopg2.connect(dbname='databasename', user='username', password='password', host='hostname')
# 创建一个Cursor:
cursor = conn.cursor()
# 执行一条SQL语句,创建表:
cursor.execute('CREATE TABLE IF NOT EXISTS user (id SERIAL PRIMARY KEY, name VARCHAR(20))')
# 关闭Cursor:
cursor.close()
# 提交事务:
conn.commit()
# 关闭Connection:
conn.close()
以上代码展示了如何连接数据库、创建一个游标对象、执行SQL语句以及关闭游标和数据库连接。每个数据库都有自己的连接方式、语法和特性,开发者需要根据实际使用的数据库类型来选择合适的API和语法。
评论已关闭