sqlite3日期数据类型

简介:

一、sqlite3日期数据类型,默认用datetime解析(根据stackflow

使用时注意三点:

  1. 创建表时,字段 DT 的类型为 date

  2. 插入数据时,DT字段直接为 str 类型

  3. DT字段的str ,年月日必须为 xxxx-xx-xx 格式,如 2016-01-01,不能是 2016-1-1

复制代码
import sqlite3
import datetime

'''sqlite3日期数据类型'''
con = sqlite3.connect(":memory:") c = con.cursor() # Create table c.execute('''CREATE TABLE marksix (DT date, Period text, P1 int, P2 int, P3 int, P4 int, P5 int, P6 int, T7 int)''') # Larger example that inserts many records at a time purchases = [('2016-01-01', '2016001', 2, 36, 23, 43, 12, 25, 29), ('2016-01-03', '2016002', 34, 35, 17, 49, 24, 30, 16), ('2016-01-05', '2016003', 1, 35, 12, 49, 49, 26, 34), ('2016-01-08', '2016004', 6, 35, 10, 40, 4, 23, 2), ('2016-01-10', '2016005', 14, 35, 27, 40, 4, 12, 45), ('2016-01-12', '2016006', 33, 10, 13, 21, 27, 22, 17), ('2016-01-15', '2016007', 20, 35, 17, 49, 5, 29, 28), ] c.executemany('INSERT INTO marksix (DT,Period,P1,P2,P3,P4,P5,P6,T7) VALUES (?,?,?,?,?,?,?,?,?)', purchases)
for row in c.execute('SELECT * FROM marksix'): print(row)
# ==============================================================

# 方式一:显式使用 datetime 类型 t = datetime.datetime.strptime('2016-1-5', '%Y-%m-%d') dt = (datetime.date(t.year, t.month, t.day), ) for row in c.execute('SELECT * FROM marksix WHERE DT = ?', dt): print(row) # 方式二:直接使用 str 类型 dt = ('2016-01-05', ) for row in c.execute('SELECT * FROM marksix WHERE DT = ?', dt): print(row)


#for row in c.execute('SELECT * FROM marksix WHERE dt BETWEEN :begin AND :end;', {"begin": '2016-01-03', "end": '2016-01-11'}): for row in c.execute('SELECT * FROM marksix WHERE dt BETWEEN ? AND ?;', ('2016-01-03', '2016-01-11')): print(row)
复制代码

 

二、另一种方式使用时间类型数据(根据官网文档

复制代码
import sqlite3
import datetime


# 适配器
def adapt_date(date):
    return datetime.datetime.strftime('%Y/%m/%d', date)
    #return date.strftime('%Y/%m/%d').encode('ascii')
    #return date.strftime('%Y/%m/%d').encode()

# 转换器
def convert_date(string):
    return datetime.datetime.strptime(string.decode(), '%Y/%m/%d')

# 注册适配器
sqlite3.register_adapter(datetime.datetime, adapt_date)

# 注册转换器
sqlite3.register_converter("date", convert_date)




# 注意:detect_types=sqlite3.PARSE_DECLTYPES
con = sqlite3.connect(":memory:", detect_types=sqlite3.PARSE_DECLTYPES)
c = con.cursor()


# Create table
c.execute('''CREATE TABLE marksix
            (dt date, period text, p1 int, p2 int, p3 int, p4 int, p5 int, p6 int, t7 int)''')


# Larger example that inserts many records at a time
purchases = [('2016/1/1', '2016001', 2, 36, 23, 43, 12, 25, 29),
             ('2016/1/3', '2016002', 34, 35, 17, 49, 24, 30, 16),
             ('2016/1/5', '2016003', 1, 35, 12, 49, 49, 26, 34),
             ('2016/1/8', '2016004', 6, 35, 10, 40, 4, 23, 2),
             ('2016/1/10', '2016005', 14, 35, 27, 40, 4, 12, 45),
             ('2016/1/12', '2016006', 33, 10, 13, 21, 27, 22, 17),
             ('2016/1/15', '2016007', 20, 35, 17, 49, 5, 29, 28),
            ]
c.executemany('INSERT INTO marksix VALUES (?,?,?,?,?,?,?,?,?)', purchases)

# Save (commit) the changes
con.commit()

for row in c.execute('SELECT * FROM marksix'):
    print(row)

# ==============================================================

# 显示日期等于2016/1/3的记录
t = ('2016/1/3',)
c.execute('SELECT * FROM marksix WHERE dt = ?', t)
print(c.fetchone())



# 貌似不支持between运算,不知原因!
for row in c.execute('SELECT * FROM marksix WHERE dt BETWEEN ? AND ?;', ('2016/1/3', '2016/1/11')):
    print(row)
复制代码

 

三、还有一种日期时间类型:timestamp(时间戳)

复制代码
import datetime


# Converting SQLite values to custom Python types
# Default adapters and converters for datetime and timestamp
con = sqlite3.connect(":memory:", detect_types=sqlite3.PARSE_DECLTYPES|sqlite3.PARSE_COLNAMES)
cur = con.cursor()

cur.execute('''create table test(
                                d date, 
                                ts timestamp
                                )''')

# 插入datetime类型
today = datetime.date.today()
now = datetime.datetime.now()
day1 = datetime.timedelta(days=1)
data = [(today-day1, now-day1),
        (today, now),
        (today+day1, now+day1)]
cur.executemany("insert into test(d, ts) values (?, ?)", data)

# 插入 str 类型
data = [('2016-01-22', '2016-01-22 08:45:50'),
        ('2016-02-22', '2016-02-22 08:45:50'),
        ('2016-03-22', '2016-03-22 08:45:50')]
cur.executemany("insert into test(d, ts) values (?, ?)", data)
        

for row in cur.execute("select * from test"):
    print(row)

#=================================================================

#begin = datetime.date(2016, 2, 22)
#end = datetime.date(2016, 2, 23)
begin = '2016-02-22'
end = '2016-02-23'
for row in cur.execute("select * from test where d BETWEEN ? AND ?", (begin, end)):
    print(row)


begin = datetime.datetime(2016, 2, 22, 8, 45, 50, 0)
end = datetime.datetime(2016, 2, 23, 20, 10, 47, 12345)
#begin = '2016-02-22 08:45:50'
#end = '2016-02-23 20:10:47'
for row in cur.execute("select * from test where ts BETWEEN ? AND ?", (begin, end)):
    print(row)
复制代码

 

本文转自罗兵博客园博客,原文链接:http://www.cnblogs.com/hhh5460/p/5205982.html ,如需转载请自行联系原作者
相关文章
|
Web App开发 域名解析 缓存
如何在 Ubuntu 20.04 上安装 Node.js 和 npm
本文我们主要为大家介绍在 Ubuntu 20.04 上安装 Node.js 和 npm 的三种不同的方式。
162455 7
如何在 Ubuntu 20.04 上安装 Node.js 和 npm
|
Oracle Ubuntu Java
Ubuntu安装JDK
一. Ubuntu 安装JDK的两种方式 1. 通过apt安装. 2. 通过官网下载安装包安装. 这里推荐第1种,因为可以通过 apt-get upgrade 方式方便获得jdk的升级 二. 通过apt安装(jdk有很多版本, 这里介绍两种: openjdk和oracle的JDK) 1.
71272 4
|
Oracle Java 关系型数据库
Oracle jdk 的国内下载镜像
Oracle jdk 的国内下载镜像
52476 0
|
应用服务中间件 nginx
Nginx的启动、停止与重启
启动  启动代码格式:nginx安装目录地址 -c nginx配置文件地址 例如: [root@LinuxServer sbin]# /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.
13109 0
|
Linux 数据安全/隐私保护 Windows
更换(Pypi)pip源到国内镜像
pip国内的一些镜像 阿里云 http://mirrors.aliyun.com/pypi/simple/ 中国科技大学 https://pypi.mirrors.
247123 2
|
12月前
|
Rust 前端开发 关系型数据库
Tauri 开发实践 — Tauri 集成本地数据库
本文介绍了在 Tauri 框架中集成本地数据库的几种方案,包括直接绑定 SQLite、使用第三方数据库库和使用 tauri-plugin-sql-api 插件。最终选择了 tauri-plugin-sql-api,因为它集成简单、支持多种数据库类型,并且与 Tauri 框架深度整合,提升了开发效率和安全性。文章详细介绍了如何安装和使用该插件,以及如何编写核心代码实现数据库操作。
883 2
|
Ubuntu 安全 Linux
在Ubuntu 20.04上安装和配置VNC的方法
在Ubuntu 20.04上安装和配置VNC的方法
1395 0
|
存储 移动开发 缓存
使用 Go 语言开发 Android 应用的正确姿势探索
使用 Go 语言开发 Android 应用的正确姿势探索
使用 Go 语言开发 Android 应用的正确姿势探索
|
存储 缓存 测试技术
sqlite 性能优化
sqlite 性能优化
1041 0
|
JavaScript
vue项目上传到宝塔刷新404?(详细教程)
vue项目上传到宝塔刷新404?(详细教程)
991 0