xiaoyanbot
V2EX  ›  问与答

SQL 语句的请教 , varchar 字段 where 条件后面 123 带不带引号, 等号能变成 LIKE ?

  •  
  •   xiaoyanbot · Sep 3, 2019 · 2279 views
    This topic created in 2452 days ago, the information mentioned may be changed or developed.

    MySQL 5.6

    username 是 varchar 类型的,username 有很多行。

    当查询:

    SELECT username FROM member WHERE username = 123
    

    出来了结果:

    0123abcd
    0123hqy
    123
    123-456
    

    ======================

    当查询:

    SELECT username FROM member WHERE username = '123' 
    

    出来的就是预期的那个

    123
    

    这是啥情况?

    6 replies    2020-11-14 10:40:59 +08:00
    xiaoyanbot
        1
    xiaoyanbot  
    OP
       Sep 3, 2019
    啥情况
    chenset
        2
    chenset  
       Sep 3, 2019
    0123abcd
    0123hqy
    123
    123-456

    这些值转为 int 都是 123.

    where 123 = 123

    我猜的
    chenset
        3
    chenset  
       Sep 3, 2019
    行为类似 php 的 string 转 int
    wd
        4
    wd  
       Sep 3, 2019 via iPhone
    所以说别用 mysql 了
    msg7086
        5
    msg7086  
       Sep 4, 2019
    是把字符串转成数字后比较,不是 like。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   5495 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 37ms · UTC 06:45 · PVG 14:45 · LAX 23:45 · JFK 02:45
    ♥ Do have faith in what you're doing.