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 ecplise在连接数据库时显示加载驱动成功但是数据库连接失败
  • ¥15 visionmaster启动失败,提示为“机器不满足授权而被禁用”
  • ¥50 用logisim设计16位单时钟周期cpu
  • ¥15 IDEA中圈复杂度如何具体设置
  • ¥50 labview采集不了数据
  • ¥15 Multisim红外倒车雷达仿真中距离问题
  • ¥15 请上面代码做什么处理或什么混淆
  • ¥15 英雄联盟自定义房间置顶
  • ¥15 W5500网线插上无反应
  • ¥15 如何用字典的Key,显示在WPF的xaml中