zhang276879619 2015-08-23 03:10 采纳率: 100%
浏览 1508
已采纳

数据库查询问题求大神解答

select unitcode from g3_unit where unitname like'%部门001%'这个可以查询出来

select unitno from g3_unit where unitcode like '1___'这个也可以查询出来

select unitno from g3_unit where unitcode like '(select unitcode from g3_unit where unitname like'%部门001%')___' 这两个加起来就不行了,我知道肯定是我写法的问题,请问各位大神怎么改一下?

  • 写回答

4条回答 默认 最新

  • IccBoY 2015-08-23 04:54
    关注

    select unitno from g3_unit where unitcode like '(select unitcode from g3_unit where unitname like'%部门001%')___'

    这句sql中子查询 用使用了 单引号 '' 这个是有问题的,会当成 字符串处理。但同时 内部有还有一组单引号 '%部门001%' 这回导致sql语句语法错误。
    第二个问题是 子查询查询出来可能有多个 结果,不能作为like的条件。如果查询出来的结果大于1个 会提示:[Err] 1242 - Subquery returns more than 1 row

    第三个问题是 你这里想实现 字符串的拼接,建议使用concat函数进行拼接。

    你可以使用 多表查询的方式来实现你要的效果:

    SELECT
    g3_unit.unitno
    FROM
    g3_unit,
    (
    SELECT
    unitcode
    FROM
    g3_unit
    WHERE
    unitname LIKE '%部门001%'
    ) tempTab
    WHERE
    g3_unit.unitcode LIKE CONCAT(tempTab.unitcode, "_")

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 在若依框架下实现人脸识别
  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同