我正在寻找使用 C# 和 python 客户端将 GUID 存储在我的 SQLite 数据库中。
创建数据库并插入一行,将 GUID 存储为字符串:
conn = sqlite3.connect(filename)
c = conn.cursor()
# Create the table. Yes, I know GUID isn't a real SQLite datatype.
c.execute('CREATE TABLE test (guid GUID PRIMARY KEY, name text)')
u = uuid.uuid4()
print u
t = (str(u), 'foo')
c.execute('INSERT INTO test VALUES (?,?)', t)
conn.commit()
conn.close()
抓取:
# ...
c.execute('SELECT * FROM test WHERE guid = "c1332103-6031-4ff7-b610-f8f3b940fa66"')
print c.fetchone()
这一切都完美无缺。使用 UUID 的默认 Python__str__
表示效果很好。
C:\Users\Jonathon>makedb.py test.db
c1332103-6031-4ff7-b610-f8f3b940fa66
C:\Users\Jonathon>opendb.py test.db
(u'c1332103-6031-4ff7-b610-f8f3b940fa66', u'foo')
我的疑虑来自使用SQLite Expert。SQLite Expert 似乎对我的 GUID 数据类型声明很满意:
但是,如果我编辑一行:
似乎它改变了数据类型!我SELECT
之前的 yield None
,如果 I SELECT *
,我看到它不再是一个简单的 unicode 字符串:
C:\Users\Jonathon>opendb.py test.db
(<read-write buffer ptr 0x02239520, size 16 at 0x02239500>, u'foo')
查看磁盘上的数据,您可以看到 GUID 以二进制形式存储,在 SQLite Expert 触摸后:
之前 - GUID 是 ASCII 文本:
之后 - 之前的数据是垃圾,并且存在 GUID 的二进制版本:
那么在 SQLite 中存储 GUID 的“正确”方法是什么,特别是使用 Python 呢?稍后,我也会让 C# 代码与之交互,并希望确保我以“正确”的方式进行操作。