Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/powerbi/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Lambda(python3.6)PyMySql查询EXISTS查询始终返回1_Mysql_Python 3.x_Aws Lambda_Slack Api - Fatal编程技术网

Lambda(python3.6)PyMySql查询EXISTS查询始终返回1

Lambda(python3.6)PyMySql查询EXISTS查询始终返回1,mysql,python-3.x,aws-lambda,slack-api,Mysql,Python 3.x,Aws Lambda,Slack Api,我试图在Lambda(python3.6)中获得一个PyMySQL查询,以返回用户是否存在。我将松弛用户ID传递到查询中。这就是我想在MySQL中检查的内容。我可以通过MySQL运行相同的查询,它返回一个0,但是由于某种原因,每次我通过lambda调用这个查询时,它都会告诉我用户存在(我的数据库是空的)。我的问题是,函数是: def userExists(user): statement = f"SELECT EXISTS(SELECT 1 FROM slackDB.Assets WHE

我试图在Lambda(python3.6)中获得一个PyMySQL查询,以返回用户是否存在。我将松弛用户ID传递到查询中。这就是我想在MySQL中检查的内容。我可以通过MySQL运行相同的查询,它返回一个0,但是由于某种原因,每次我通过lambda调用这个查询时,它都会告诉我用户存在(我的数据库是空的)。我的问题是,函数是:

def userExists(user):
    statement = f"SELECT EXISTS(SELECT 1 FROM slackDB.Assets WHERE userID LIKE '%{user}%')Assets"
    tempBool  = cursor.execute(statement, args=None) 
    conn.commit()
    return tempBool
以下是我正在使用的完整代码:

################################
# Slack Lambda handler.
################################

import sys
import logging
import os
import pymysql
import urllib

# Grab data from the environment.
BOT_TOKEN   = os.environ["BOT_TOKEN"]
ASSET_TABLE = os.environ["ASSET_TABLE"]
REGION_NAME = os.getenv('REGION_NAME', 'us-east-2')

DB_NAME     = "admin"
DB_PASSWORD = "somepassword"
DB_DATABASE = "someDB"
RDS_HOST    = "myslackdb.somepseudourl.us-east-2.rds.amazonaws.com"
port        = 3306

logger = logging.getLogger()
logger.setLevel(logging.INFO)

try:
    conn = pymysql.connect(RDS_HOST, user=DB_NAME, passwd=DB_PASSWORD, db=DB_DATABASE, connect_timeout=5)
    cursor = conn.cursor()
except:
    logger.error("ERROR: Unexpected error: Could not connect to MySql instance.")
    sys.exit()

# Define the URL of the targeted Slack API resource.
SLACK_URL = "https://slack.com/api/chat.postMessage"

def userExists(user):
    statement = f"SELECT EXISTS(SELECT 1 FROM slackDB.Assets WHERE userID LIKE '%{user}%')Assets"
    tempBool  = cursor.execute(statement, args=None) 
    conn.commit()
    return tempBool

def addUser(user):
    statement = f"INSERT INTO `slackDB`.`Assets` (`userID`, `money`) VALUES ('{user}', '1000')"
    tempBool  = cursor.execute(statement, args=None) 
    conn.commit()
    return tempBool

def lambda_handler(data, context):
    # Slack challenge answer.
    if "challenge" in data:
        return data["challenge"]

    # Grab the Slack channel data.
    slack_event    = data['event']
    slack_userID   = slack_event["user"]
    slack_text     = slack_event["text"]
    channel_id     = slack_event["channel"]
    slack_reply    = ""

    # Ignore bot messages.
    if "bot_id" in slack_event:
        slack_reply = ""
    else:
        # Start data sift.
        if slack_text.startswith("!networth"):
            slack_reply = "Your networth is: "
        elif slack_text.startswith("!price"):
            command,asset = text.split()
            slack_reply = f"The price of a(n) {asset} is: "
        elif slack_text.startswith("!addme"):
            if userExists(slack_userID):
                slack_reply = f"User {slack_userID} already exists"
            else:
                slack_reply = f"Adding user {slack_userID}"
                addUser(slack_userID)

        # We need to send back three pieces of information:
        data = urllib.parse.urlencode(
            (
                ("token", BOT_TOKEN),
                ("channel", channel_id),
                ("text", slack_reply)
            )
        )
        data = data.encode("ascii")

        # Construct the HTTP request that will be sent to the Slack API.
        request = urllib.request.Request(
            SLACK_URL, 
            data=data, 
            method="POST"
        )
        # Add a header mentioning that the text is URL-encoded.
        request.add_header(
            "Content-Type", 
            "application/x-www-form-urlencoded"
        )

        # Fire off the request!
        urllib.request.urlopen(request).read()

    # Everything went fine.
    return "200 OK"
我在打字!在slack中添加我,它总是告诉我用户存在。我已经打印出我的查询语句,它正确地输入了我的slack ID。我检查过我的桌子,它是空的。我在MySQL中运行了这个查询,它返回一个0

有人有什么想法吗?我是不是在简单的事情上搞清楚了?任何帮助或暗示都将不胜感激


谢谢,

我没有看到从光标中提取
。只需执行

execute
返回的是受影响的行数。对于有意义的DML操作(插入/更新/删除)。但我不会依赖受影响的行数进行选择

在这种情况下,
SELECT EXISTS
查询将返回一行或抛出一个错误。但是查询返回一行的事实并没有告诉我们有关
资产
列的任何值

从查询中,我们似乎要获取一行,然后确定
Assets
列是否包含0或1(或NULL)

执行查询后,请尝试
cur.fetchone
检索行



我们还可以执行一个更简单的查询,然后使用fetch来确定是否返回了一行。

cursor.execute(statement,args=None)tempBool=cursor.fetchone()刚刚尝试过这个方法,它没有返回任何错误(耶!),但每次都返回1。有什么想法吗?所以fetch回了一个问题。这正是我们所期望的<代码>选择存在
将返回一行。重要的是行的内容。。。
Assets
列是等于1(至少找到一行),还是等于0(没有找到行)。这就是我们可以简化事情的地方。。。放弃SELECT EXISTS包装器,只运行返回行(如果找到一行)或不返回行(当找不到行时)的查询。我们可以添加一个LIMIT 1子句以避免返回多行,我们只关心是否返回一行。然后我们可以使用从
fetchone
返回。如果我们坚持使用
SELECT EXISTS
查询,我们需要实际获取行,并检查返回的行。我们需要获取
资产
列的值。谢谢!我将尝试放弃选择存在并添加限制1。感谢你的解释。