Navigation

    Odoo 中文社区

    • Register
    • Login
    • Search
    • Categories
    • Tags
    • Popular
    • Users
    • Groups

    Odoo中文社区可以通过以下两个域名访问:shine-it.net , odoo.net.cn

    由于系统升迁的原因,本论坛部分较早期的内容存在格式和链接损坏失效的问题,并非本论坛系统本身的缺陷,望谅解

    本社区没有维护任何QQ群讨论组,任何与本社区同名的QQ群讨论组的言论与本社区无关!

    开发人员可以登录gitter讨论组: http://gitter.im/odoo-china/Talk, 需要github账号

    如果您登录系统碰到问题,请在微信公众号留言:

    直接通过SQL 访问取得的结果,能否是个 字典 ?

    Odoo 开发与实施交流
    2
    5
    3205
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • C
      ccdos last edited by

              sql = "SELECT top 10 * FROM askht_cs"
              cur.execute(sql)
              res  = cur.fetchone()

              i = 0
              while resault:
                  print res 
                  print "categoriesId=%s , categoriesName=%s" % (res[0], res[1])

      ~~~~~~~~~~~~~~~~~~~~
      上面 这样的写法, 返回值res  是个  tuple, 字段多的时候 很不直观
      有没有办法 返回一个 字典 ?  用字段名访问呢?

      1 Reply Last reply Reply Quote 0
      • C
        ccdos last edited by

                res = cr.dictfetchone()
                if res:
                    return bool(res['debit'] and res['credit'])

        ~~~~~~~~~
        找到了 dictfetchone() ,


        不过可惜了

        我用的 pymssql  接口 , 不带这个

        1 Reply Last reply Reply Quote 0
        • C
          ccdos last edited by

          开源就是好, 再仔细 学习 发现,

          pymssql  有个属性  as_dict , 看起来就是我要的功能, 具体怎么用呢 ?

          放狗一搜
          人家 官网的 wiki 上面写得清清楚楚
          <br / http://code.google.com/p/pymssql/wiki/PymssqlExamples br />


          Rows as dictionaries
          Since pymssql 1.0.2 rows can be fetched as dictionaries instead of tuples. This allows for accessing columns by name instead of index. Note the as_dict argument.

          import pymssql
          conn = pymssql.connect(host='SQL01', user='user', password='password', database='mydatabase', as_dict=True)
          cur = conn.cursor()


          圆满 ,收工.


          btw: 居然还支持 用 中文字段名 .别见笑, 咱的老系统, 用中文字段名 很多

          1 Reply Last reply Reply Quote 0
          • mrshelly
            mrshelly last edited by

            是的.... 没有注意到这贴...  就是 connect 的时候. as_dict 就OK了.
            不过,要注意 pymssql 的版本. 低版本的不支持这个 as_dict.

            1 Reply Last reply Reply Quote 0
            • First post
              Last post