我目前正在使用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 查询的正确方法吗(我假设不是)?
每当创建或登录用户帐户时都会使用此查询(因为它必须检查用户名是否存在于系统中)。我知道这不是最有效的查询,所以它是否只用于登录或帐户创建是否重要?是否更可取的是强制用户只选择小写用户名(完全不需要不区分大小写的查询)?