Maison> base de données> tutoriel mysql> le corps du texte

Comment résoudre l'erreur lors de l'exécution de l'instruction MySQL en Python

王林
Libérer: 2023-05-29 13:34:06
avant
1969 Les gens l'ont consulté

一 python signale une erreur lors de l'exécution de l'instruction mysql

Comme nous le savons tous, python a un mécanisme de traduction %s et %d sera traduit en chaînes. ou des nombres, et les requêtes floues de SQL doivent également utiliser %. Lors de l'exécution de requêtes floues, il serait très embarrassant si la condition de requête est toujours une variable.

La solution est en fait très simple, il suffit d'extraire les chaînes qui doivent être interrogées de manière floue à partir du SQL et de les assembler

Dans le mauvais sens

shopId = "zbw_010002"
'''select * from base_saleflows where shopId='{0}' and card_id is not NULL and standard_cls4 like "%湿巾%" '''.format(shopId)
Copier après la connexion

J'ai trouvé que c'était faux, mysql ne peut pas exécuter une telle instruction.

Comment résoudre lerreur lors de lexécution de linstruction MySQL en Python

args='%湿巾%'shopId = "zbw_010002"mysql_sentence='''select a.shopId, a.sale_money,a.card_id ,a.standard_cls4 from base_saleflows a join base_vips b on a.card_id = b.card_id where a.shopId='{0}' and a.card_id is not NULL and a.standard_cls4 like '{1}' '''.format(shopId,args)print(mysql_sentence)
Copier après la connexion

Le résultat est

select * from base_saleflows a join base_vips b on a.card_id = b.card_id where a.shopId='zbw_010002' and a.card_id is not NULL and a.standard_cls4 like '%湿巾%'
Copier après la connexion

2 Regroupement et épissage de chaînes

Regroupez et épissez les chaînes pour la colonne cls3 selon le numéro de série flow_no, le symbole d'épissage est '- '# #

# 分组拼接result = vipsaleflow_common.pivot_table(values='standard_cls3',index='flow_no',aggfunc=lambda x:x.str.cat(sep='-'))
Copier après la connexion

Comment résoudre lerreur lors de lexécution de linstruction MySQL en Python

Application : Selon

(année, trimestre, numéro d'agence, type lingettes humides)Groupe pour trouver le nombre de nouveaux clients pour chaquetrimestre

quatre Dérivé en fonction de l'année d'horodatage et trimestre du mois# #

saleflow['oper_date']=saleflow['oper_date'].astype(str) #字符串saleflow['oper_date'] = saleflow.oper_date.apply(lambda x:datetime.strptime(x, '%Y-%m-%d %H:%M:%S'))saleflow["month"] = saleflow.oper_date.map(lambda x: x.month)saleflow["year"] = saleflow.oper_date.map(lambda x: x.year)#https://www.it1352.com/584941.htmllookup = {1: 1, 2: 1,3: 1,4: 2, 5: 2, 6: 2, 7: 3,8: 3,9: 3,10: 4, 11: 4,12: 4}saleflow['Season'] = saleflow['oper_date'].apply(lambda x: lookup[x.month]) saleflow['YearMonth'] = saleflow['oper_date'].map(lambda x: 100*x.year + x.month)
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:yisu.com
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!