SQL sever根据身份证判断性别函数

1. 基本查询示例

sql

复制代码
-- 假设表名为 users,身份证字段名为 id_card
SELECT 
    id_card,
    SUBSTRING(id_card, 17, 1) AS 第17位, -- 截取第17位
    CASE 
        WHEN CAST(SUBSTRING(id_card, 17, 1) AS INT) % 2 = 1 
        THEN '男' 
        ELSE '女' 
    END AS 性别
FROM users
WHERE LEN(id_card) = 18; -- 确保是18位身份证

2. 完整函数封装

sql

复制代码
-- 创建判断性别的函数
CREATE FUNCTION dbo.GetGenderByIdCard(@id_card VARCHAR(18))
RETURNS VARCHAR(2)
AS
BEGIN
    DECLARE @gender VARCHAR(2)
    
    IF LEN(@id_card) <> 18 OR ISNUMERIC(SUBSTRING(@id_card, 1, 17)) = 0
        RETURN '无效' -- 身份证格式不正确
        
    IF CAST(SUBSTRING(@id_card, 17, 1) AS INT) % 2 = 1
        SET @gender = '男'
    ELSE
        SET @gender = '女'
        
    RETURN @gender
END

使用函数:

sql

复制代码
SELECT id_card, dbo.GetGenderByIdCard(id_card) AS 性别
FROM users

3. 包含15位和18位身份证的判断

sql

复制代码
SELECT 
    id_card,
    CASE 
        WHEN LEN(id_card) = 15 THEN -- 15位旧身份证
            CASE 
                WHEN CAST(SUBSTRING(id_card, 15, 1) AS INT) % 2 = 1 
                THEN '男' 
                ELSE '女' 
            END
        WHEN LEN(id_card) = 18 THEN -- 18位新身份证
            CASE 
                WHEN CAST(SUBSTRING(id_card, 17, 1) AS INT) % 2 = 1 
                THEN '男' 
                ELSE '女' 
            END
        ELSE '格式错误'
    END AS 性别
FROM users

注意事项

  1. 异常处理:在实际使用时需要确保截取的字符是数字

  2. 性能优化:如果数据量较大,可以添加索引

  3. 数据验证:应先验证身份证格式是否正确

sql

复制代码
-- 更安全的查询(处理可能的非数字情况)
SELECT 
    id_card,
    CASE 
        WHEN ISNUMERIC(SUBSTRING(id_card, 17, 1)) = 1
        THEN CASE 
                WHEN CAST(SUBSTRING(id_card, 17, 1) AS INT) % 2 = 1 
                THEN '男' 
                ELSE '女' 
             END
        ELSE '未知'
    END AS 性别
FROM users
WHERE LEN(id_card) = 18;

提取年龄等其他信息(扩展)

sql

复制代码
-- 提取出生日期和计算年龄
SELECT 
    id_card,
    CASE 
        WHEN LEN(id_card) = 18 
        THEN CONVERT(DATE, SUBSTRING(id_card, 7, 8))
        WHEN LEN(id_card) = 15 
        THEN CONVERT(DATE, '19' + SUBSTRING(id_card, 7, 6))
    END AS 出生日期,
    DATEDIFF(YEAR, 
        CONVERT(DATE, 
            CASE 
                WHEN LEN(id_card) = 18 
                THEN SUBSTRING(id_card, 7, 8)
                WHEN LEN(id_card) = 15 
                THEN '19' + SUBSTRING(id_card, 7, 6)
            END
        ), 
        GETDATE()
    ) AS 年龄
FROM users
相关推荐
人道领域几秒前
【LeetCode刷题日记】二叉树层序遍历完全指南:从基础到LeetCode实战一篇搞定BFS模板,秒杀4道经典面试题
java·开发语言·数据结构·leetcode·面试·二叉树
承渊政道4 分钟前
CentOS 7部署Elasticsearch完整流程:避坑、基础操作、远程访问
java·linux·elasticsearch·系统架构·centos·远程工作·持续部署
weixin_444012935 分钟前
SQL中如何实现基于条件的批量逻辑删除_过滤与更新状态位
jvm·数据库·python
萤萤七悬11 分钟前
【人工智能训练师3级】考试准备(2026)三、实操题1.1.3-3.2.5
前端·数据库·人工智能
m0_6138562913 分钟前
Python中PyTorch模型如何显存优化_使用梯度检查点减少显存占用
jvm·数据库·python
米高梅狮子17 分钟前
13.ETCD 存储系统、生产环境 Kubernetes 集群部署和Kubernetes 集群升级
数据库·云原生·容器·架构·kubernetes·自动化·etcd
咖啡八杯19 分钟前
GoF设计模式——工厂方法模式
java·后端·设计模式
Yupureki20 分钟前
《MySQL数据库基础》6.表的增删查改
linux·服务器·数据库·mysql
北顾笙98025 分钟前
MySQL-day1
数据库·mysql
代码羊羊1 小时前
Rust 迭代器完全通俗易懂指南(零基础全覆盖)
java·开发语言·rust