我目前正在python(金字塔)创建一个网站,要求用户注册并登录。系统允许用户选择可以混合使用大写字母,小写字母和数字的用户名。
当确保两个用户不会意外共享相同的用户名时出现问题,即在我的系统中,“randomUser”应该与“RandomUser”或“randomuser”相同。
不幸的是(在这种情况下),因为Mongo将字符串存储为区分大小写,所以可能会有一些具有“相同”用户名的用户。
我知道查询mongo不区分大小写字符串的方法:
db.stuff.find_one({"foo": /bar/i});
但是,使用pymongo的查询方法似乎不起作用:
username = '/' + str(username) + '/i'
response = request.db['user'].find_one({"username":username},{"username":1})
这是构造pymongo查询的正确方法(我假设没有)?
每当创建或登录用户帐户时,将使用此查询(因为必须检查系统中是否存在该用户名)。我知道这不是最有效的查询,如果只用于登录或帐户创建,那么它应该是重要的?是否更喜欢做一些类似强制用户只选择小写的用户名(完全不需要不区分大小写的查询)?