flask_sqlachemy查询字段区分大小写

15 篇文章 0 订阅
10 篇文章 1 订阅

场景:

mysql  校验集指定 utf8mb4_unicode_ci 大小写不敏感 

登录用户为admin,此时填写ADMIN也能登录,如果用户名需要区分大小写,你的做法是什么?

mysql中的排序规则

utf8_bin将字符串中的每一个字符用二进制数据存储,区分大小写。utf8_genera_ci不区分大小写,ci为case insensitive的缩写,即大小写不敏感。utf8_general_cs区分大小写,cs为case sensitive的缩写,即大小写敏感。(注意:在mysql5.6.10版本中,不支持utf8_genral_cs!!!

解决方案一

sqlalchemy指定校验规则

指定校验集为 utf8mb4_bin 大小写敏感,但是这个校验集搞砸ORDER BY

解决方案二

直接修改sql语句,在要查询的字段前面加上binary关键字

-- 在每一个条件前加上binary关键字
select * from user where binary username = 'admin' and binary password = 'admin';

-- 将参数以binary('')包围
select * from user where username like binary('admin') and password like binary('admin');

flask_sqlachemy对应语法


from sqlalchemy import func

data =  db.session.query(User).filter(User.username == func.binary(input_name)).first()

data =  db.session.query(User).filter(User.username.like(func.binary("%" + input_name + "%"))).all()
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值