MySQL根据身份证获取省份 年龄 性别

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS PostgreSQL,高可用系列 2核4GB
简介: MySQL根据身份证获取省份 年龄 性别

SQL语句

`select case left(id_card,2)

when ‘11’ then ‘北京市’

when ‘12’ then ‘天津市’

when ‘13’ then ‘河北省’

when ‘14’ then ‘山西省’

when ‘15’ then ‘内蒙古自治区’

when ‘21’ then ‘辽宁省’

when ‘22’ then ‘吉林省’

when ‘23’ then ‘黑龙江省’

when ‘31’ then ‘上海市’

when ‘32’ then ‘江苏省’

when ‘33’ then ‘浙江省’

when ‘34’ then ‘安徽省’

when ‘35’ then ‘福建省’

when ‘36’ then ‘江西省’

when ‘37’ then ‘山东省’

when ‘41’ then ‘河南省’

when ‘42’ then ‘湖北省’

when ‘43’ then ‘湖南省’

when ‘44’ then ‘广东省’

when ‘45’ then ‘广西壮族自治区’

when ‘46’ then ‘海南省’

when ‘50’ then ‘重庆市’

when ‘51’ then ‘四川省’

when ‘52’ then ‘贵州省’

when ‘53’ then ‘云南省’

when ‘54’ then ‘西藏自治区’

when ‘61’ then ‘陕西省’

when ‘62’ then ‘甘肃省’

when ‘63’ then ‘青海省’

when ‘64’ then ‘宁夏回族自治区’

when ‘65’ then ‘新疆维吾尔自治区’

when ‘71’ then ‘台湾省’

when ‘81’ then ‘香港特别行政区’

when ‘82’ then ‘澳门特别行政区’

else ‘未知’

end as 省份 ,

year(curdate())-if(length(id_card)=18,substring(id_card,7,4),if(length(id_card)=15,concat(‘19’,substring(id_card,7,2)),null)) as 年龄,

case if(length(id_card)=18, cast(substring(id_card,17,1) as UNSIGNED)%2, if(length(id_card)=15,cast(substring(id_card,15,1) as UNSIGNED)%2,3))

when 1 then ‘男’

when 0 then ‘女’

else ‘未知’

end as 性别

FROM user

附加一句根据身份证获取年龄并取年龄大于6岁的sql

SELECT
  * 
FROM
USER 
WHERE
  YEAR ( curdate( ) ) -
IF
  (
    length( a.id_card ) = 18,
    substring( a.id_card, 7, 4 ),
  IF
    (
      length( a.id_card ) = 15,
      concat( '19', substring( a.id_card, 7, 2 ) ),
    NULL 
    ) 
  ) >6
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
存储 SQL 关系型数据库
MySQL设计规约问题之存储状态、性别等信息时,应该使用哪种数据类型
MySQL设计规约问题之存储状态、性别等信息时,应该使用哪种数据类型
|
SQL 关系型数据库 MySQL
【MySQL】如何快速检索邮箱号以及身份证?
【MySQL】如何快速检索邮箱号以及身份证?
547 0
|
关系型数据库 MySQL
MySql 627.变更性别
MySql 627.变更性别
121 0
MySql 627.变更性别
|
关系型数据库 MySQL
MySQL练习7——查找年龄大于24的用户信息
MySQL练习7——查找年龄大于24的用户信息!
|
21天前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
57 3
|
27天前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
2月前
|
存储 运维 关系型数据库
从MySQL到云数据库,数据库迁移真的有必要吗?
本文探讨了企业在业务增长背景下,是否应从 MySQL 迁移至云数据库的决策问题。分析了 MySQL 的优势与瓶颈,对比了云数据库在存储计算分离、自动化运维、多负载支持等方面的优势,并提出判断迁移必要性的五个关键问题及实施路径,帮助企业理性决策并落地迁移方案。
|
15天前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
16天前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
|
16天前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。

推荐镜像

更多