“execute statement”中出现意外的关键字参数。

huangapple go评论107阅读模式
英文:

unexpected keyword argument in execute statement

问题

  1. def add_application_to_db(job_id, data):
  2. with engine.connect() as conn:
  3. sql = text(
  4. "INSERT INTO application(id,job_id,fullname,email,linkedin,education,experience,resumeurl) VALUES (:job_id,:fullname,:email,:linkedin,:education,:experience,:resumeurl)"
  5. )
  6. conn.execute(
  7. job_id=job_id,
  8. fullname=data["fullname"],
  9. email=data["email"],
  10. linkedin=data["linkedin"],
  11. education=data["education"],
  12. experience=data["experience"],
  13. resumeurl=data["resumeurl"],
  14. )
英文:
  1. def add_application_to_db(job_id, data):
  2. with engine.connect() as conn:
  3. sql = text(
  4. "INSERT INTO application(id,job_id,fullname,email,linkedin,education,experience,resumeurl) VALUES (:job_id,:fullname,:email,:linkedin,:education,:experience,:resumeurl)"
  5. )
  6. conn.execute(
  7. job_id=job_id,
  8. fullname=data["fullname"],
  9. email=data["email"],
  10. linkedin=data["linkedin"],
  11. education=data["education"],
  12. experience=data["experience"],
  13. resumeurl=data["resumeurl"],
  14. )

I am learning flask and using MySQL and sqlalchemy.I am trying to store info from user into the data base (table name = application)
I got following error
>TypeError: Connection.execute() got an unexpected keyword argument 'job_id'

答案1

得分: 0

如果您正在使用SQLAlchemy 2.0,则必须将参数发送为字典,而不是您现在尝试的方式。

  1. def add_application_to_db(job_id, data):
  2. row = {
  3. "job_id": job_id,
  4. "fullname": data["fullname"],
  5. "email": data["email"],
  6. "linkedin": data["linkedin"],
  7. "education": data["education"],
  8. "experience": data["experience"],
  9. "resumeurl": data["resumeurl"],
  10. }
  11. with engine.connect() as conn:
  12. sql = text(
  13. "INSERT INTO application(id,job_id,fullname,email,linkedin,education,experience,resumeurl) VALUES (:job_id,:fullname,:email,:linkedin,:education,:experience,:resumeurl)"
  14. )
  15. conn.execute(sql, row)
英文:

If you are using SQLAlchemy 2.0 then you have to send the parameters as a dict instead of what you are trying now.

  1. def add_application_to_db(job_id, data):
  2. row = {
  3. "job_id": job_id,
  4. "fullname": data["fullname"],
  5. "email": data["email"],
  6. "linkedin": data["linkedin"],
  7. "education": data["education"],
  8. "experience": data["experience"],
  9. "resumeurl": data["resumeurl"],
  10. }
  11. with engine.connect() as conn:
  12. sql = text(
  13. "INSERT INTO application(id,job_id,fullname,email,linkedin,education,experience,resumeurl) VALUES (:job_id,:fullname,:email,:linkedin,:education,:experience,:resumeurl)"
  14. )
  15. conn.execute(sql, row)

huangapple
  • 本文由 发表于 2023年6月15日 13:56:11
  • 转载请务必保留本文链接:https://go.coder-hub.com/76479491.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定