卡bin查询sql分享
admin
2023-05-08 20:01:59
0

卡bin:卡号的前6位数字代表发卡行标识代码,也叫BIN号,不同的BIN号代表了不同的银行卡组织和卡片级别。


最近更新了系统的卡bin表数据(bank_card_bin),发现卡bin长度并不是前述的6位数字,卡bin长度为8位(有些6位、有些7位,非定长),如下表,


支行行名称卡名卡类型卡bin卡bin长度长度组织码
乌拉特中旗蒙银村镇银行乌拉特中旗蒙银村镇银行蒙银借记卡借记卡6213460781915142075
磴口蒙银村镇银行磴口蒙银村镇银行蒙银借记卡借记卡6213462681915142073
鄂托克前旗蒙银村镇银行鄂托克前旗蒙银村镇银行蒙银借记卡借记卡6213462481915142054
鄂尔多斯市铁西蒙银村镇银行鄂尔多斯市铁西蒙银村镇银行蒙银借记卡借记卡6213461181915142051
四子王蒙银村镇银行四子王蒙银村镇银行蒙银借记卡借记卡6213461381915142046


那么如何根据银行卡号查询具体的卡信息呢?

最开始的想法是截图卡号前6位,并限制卡长度进行查询,若返回结果不是只有一条则继续截取前7位进行查询,直到只有一条返回结果。若有2条及以上结果时,继续查询却有0条记录,则认为未收录该卡bin数据。即递归查询。假设卡号为6213462465616156,参考sql如下

select * from bank_card_bin
where  '6213462465616156'  like '621346%' and  长度 = '19'


但是,这太麻烦了,怎么可能呢?在同事沟通确认,可以做些变更,如下

select * from bank_card_bin
where '6213462465616156' like concat(卡bin,'%') and  长度 = '19'

巧妙地将前一个sql拆成了两段,且卡bin不是由用户自己判断截取的,是做匹配。

同时,此sql利用了“卡bin是唯一”的特性,不存在包含关系,即不存在以下的记录,

***银行**银行蒙银借记卡借记卡6213466191514204


相关内容

热门资讯

凤凰独家:特朗普二儿子与夫人参... 凤凰独家报道,中美元首会谈期间,特朗普二儿子埃里克·特朗普与夫人参观人民大会堂,并在《江山如此多娇》...
联合国赞赏中美就伊朗问题保持沟... 联合国秘书长古特雷斯13日通过副发言人哈克表示,欢迎中美元首会晤,赞赏两国通过对话沟通妥善处理分歧。...
特稿|拉长合作清单 贡献建设性... 新华社北京5月13日电 题:拉长合作清单 贡献建设性力量——美国商学界人士瞩望美中经贸关系互利共赢新...
中国量子计算新突破!“九章四号... 记者从中国科学技术大学获悉,由该校潘建伟院士领衔的科研团队联合国内多家科研机构、大学,近期成功研制出...
跳河救人的外卖小哥找到了! 外... 5月12日下午5时许,漯河市郾城区孟庙镇幸福渠河堤旁,57岁的甘女士蹲在河边打水,准备回家给鱼换水,...
今年以来,越来越多美国交流团来... 4月,数十名美国犹他州青少年来豫参加2026年YES项目交流活动。图为美国青少年在郑州体验书法项目。...
“打工机器人”亮相郑州街头 机器人服务员“小盖”在郑州街边的一零售店工作。 王磊 摄机器人当服务员,在街头卖咖啡——这不是科幻电...
打响“河南服务”品牌丨盾构机有... 【开栏的话】为深入贯彻落实全省服务业大会精神,本报即日起开设“打响‘河南服务&rsquo...
一季度我国数字产业收入9.5万... 【大河财立方消息】5月14日,工信部发布的数据显示,一季度,我国数字产业实现良好开局,行业利润大幅改...
一体推进整治形式主义为基层减负... 形式主义实质是主观主义、功利主义,根源是政绩观错位、责任心缺失。当前,各地以深化“六个纠治”为抓手,...