簡體   English   中英

使用python查詢SQL

[英]Query SQL by using python

我嘗試使用python查詢SQL,但返回問號。

這是我的代碼。

import cx_Oracle
import importlib

class CustomDatabase(object):

    ROBOT_LIBRARY_SCOPE = 'GLOBAL'

    def __init__(self):
        """
        Initializes _dbconnection to None.
        """
        self._dbconnection = None
        self.db_api_module_name = None

    def GetDataFromDatabaseByRow(self, db_connect_string, selectStatement, row):
        db_api_2 = importlib.import_module("cx_Oracle")
        db_connect_string = 'db_api_2.connect(%s)' % db_connect_string
        self.db_api_module_name = "cx_Oracle"
        self._dbconnection = eval(db_connect_string)
        row = int(row)
        cur = None
        try:
            cur = self._dbconnection.cursor()
            cur.execute(selectStatement)
            res = cur.fetchone()
            i = 0
            while (i < row):
                if cur.rowcount == row:
                    data = res
                res = cur.fetchone()
                i = i + 1
                if i == row:
                    for x in data:  
                        result=x
            #return result.decode('iso-8859-11')
            return result
        finally :
            if cur :
                self._dbconnection.rollback()

Obj=CustomDatabase()
A=Obj.GetDataFromDatabaseByRow("'BELL', 'BELL#', '192.168.1.10:110/BELL'","select book_name from book where id='100'",1)
print A

這是實際結果。

OOP ???????

這是數據庫中的值。

OOP แม่เจ้า

我希望期望值是OOP แม่เจ้า (泰語)。

請你幫助我好嗎?

例如,在啟動Python之前設置Oracle NLS_LANG環境變量

export NLS_LANG=.AL32UTF8

(是的,在'='之后有句號)。

Oracle有關全球化的文檔是《 數據庫全球化支持指南》

[更新] @ anthony-tuininga 指出 ,您可以執行以下操作:

import cx_Oracle conn = cx_Oracle.connect(connectString, encoding = "UTF-8", nencoding = "UTF-8")

在此示例中不需要NLS_LANG 如果不使用NCHAR數據,則可以省略nencoding選項。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM