weixin_52834332 2021-09-19 11:13 采纳率: 77.4%
浏览 18
已结题

想知道我下面这个数据库的语句为什么显示报错?

```sql

use teaching2021;
select id,idcard,if(substring(idcard,17,1)%2=1,'男','女')as'性别'
from identity

```)
题目要求根据身份证号来辨别性别

  • 写回答

1条回答 默认 最新

  • wo.austin 2021-09-19 11:58
    关注

    substring(idcard,17,1)是字符串切割,切割结果也是字符串,但是,%2是数值运算,类型不匹配。你可以改为

    select id,idcard,if(substring(idcard,17,1) in('1','3','5','7','9'),'男''女') as '性别' 
    from `teaching2021`.identity
    

    里面的"use teaching2021;"也不需要了

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 9月27日
  • 已采纳回答 9月19日
  • 创建了问题 9月19日

悬赏问题

  • ¥15 (标签-UDP|关键词-client)
  • ¥15 关于库卡officelite无法与虚拟机通讯的问题
  • ¥15 qgcomp混合物线性模型分析的代码出现错误:Model aliasing occurred
  • ¥100 已有python代码,要求做成可执行程序,程序设计内容不多
  • ¥15 目标检测项目无法读取视频
  • ¥15 GEO datasets中基因芯片数据仅仅提供了normalized signal如何进行差异分析
  • ¥15 小红薯封设备能解决的来
  • ¥100 求采集电商背景音乐的方法
  • ¥15 数学建模竞赛求指导帮助
  • ¥15 STM32控制MAX7219问题求解答