V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
miniyao

Python ORM 为什么可以不区分变量类型?

  •  
  •   miniyao · Jul 12, 2018 · 4909 views
    This topic created in 2852 days ago, the information mentioned may be changed or developed.

    book 的 id 存在数据库里是 int,但查询的时候,给一个 int 和 string 都可以查:

    book = Book.query.filter(Book.id == book_id).first()
    
    book = Book.query.filter(Book.id == str(book_id)).first()
    
    4 replies    2018-07-13 00:47:52 +08:00
    DonaidTrump
        1
    DonaidTrump  
       Jul 12, 2018 via iPhone   ❤️ 1
    是数据库不分 int 跟 string
    miniyao
        2
    miniyao  
    OP
       Jul 12, 2018
    @tulongtou 在数据库里,还是指定了 book 的 id 类型 为 int 的呀
    yemoluo
        3
    yemoluo  
       Jul 12, 2018   ❤️ 1
    @miniyao 因为数据库会做一些转换

    SELECT * FROM book WHERE id= 1 LIMIT 1;



    SELECT * FROM book WHERE id= '1' LIMIT 1;

    是一样的
    Qzier
        4
    Qzier  
       Jul 13, 2018 via iPhone
    最后都会拼接成原生 sql 语句,都一样
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2345 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 46ms · UTC 15:39 · PVG 23:39 · LAX 08:39 · JFK 11:39
    ♥ Do have faith in what you're doing.