miniyao

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

  •  
  •   miniyao · Jul 12, 2018 · 4928 views
    This topic created in 2859 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   ·   3226 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 42ms · UTC 14:19 · PVG 22:19 · LAX 07:19 · JFK 10:19
    ♥ Do have faith in what you're doing.