跳转至内容
  • 版块
  • 标签
  • 热门
  • 用户
  • 群组
皮肤
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • 默认(Flatly)
  • 不使用皮肤
折叠

Odoo 中文社区

  1. 主页
  2. 版块
  3. Odoo 开发与实施交流
  4. 直接通过SQL 访问取得的结果,能否是个 字典 ?

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

已定时 已固定 已锁定 已移动 Odoo 开发与实施交流
5 帖子 2 发布者 3.6k 浏览
  • 从旧到新
  • 从新到旧
  • 最多赞同
登录后回复
此主题已被删除。只有拥有主题管理权限的用户可以查看。
  • C 离线
    C 离线
    ccdos
    写于 最后由 编辑
    #1

            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 条回复 最后回复
    0
    • C 离线
      C 离线
      ccdos
      写于 最后由 编辑
      #2

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

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


      不过可惜了

      我用的 pymssql  接口 , 不带这个

      1 条回复 最后回复
      0
      • C 离线
        C 离线
        ccdos
        写于 最后由 编辑
        #3

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

        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 条回复 最后回复
        0
        • mrshellyM 离线
          mrshellyM 离线
          mrshelly
          写于 最后由 编辑
          #4

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

          1 条回复 最后回复
          0

          • 登录

          • 没有帐号? 注册

          • 登录或注册以进行搜索。
          • 第一个帖子
            最后一个帖子
          0
          • 版块
          • 标签
          • 热门
          • 用户
          • 群组