mysql.connector.errors.DataError: 1406 (22001): Data too long for column
mysql.connector.errors.DataError: 1406 (22001): Data too long for column
我在 MySQL db 中存储使用 Reportlab 库制作的 PDF 文件时遇到问题。这是我的代码:
def insertIntoDb(pdfFullPath,name,surname,gravity):
print('PRIMA DEL MYSQL')
print('pdf full path'+pdfFullPath)
mydb = mysql.connector.connect(host="localhost", user="root", passwd="", database="deepface")
with open(pdfFullPath,'rb') as pdfvar:
blob = pdfvar.read()
print(blob)
sqlQuery = "INSERT INTO diagnosi(name,surname,pdf,gravity) VALUES (%s,%s,%s,%s)"
mycursor = mydb.cursor()
val = (name,surname,blob,gravity,)
mycursor.execute(sqlQuery,val)
mydb.commit()
mycursor.close()
mydb.close()
控制台显示:
mysql.connector.errors.DataError: 1406 (22001): Data too long for column 'pdf' at row 1
我已经在 mysql 配置文件中设置了最大允许数据包,但问题是当我尝试打印(我知道我不能)PDF 时,我得到了这个:
^\7:[,1qq,N_Sd$dm-:XU2/Pga=O1f/`hY7X1nrca).:_\'-4,n*"L5r,CHFpGo:"E,MDLu7EW%CFF0$Rl?jT\'6%k%,?AF%UK6ojt/c$<^Xh=;VarY:L8cQYTgj/:CfA/j1=dbU@a<:%D;rDV[)WDu)5*"98A5kkfYAqs0FFVZk[*Mb(Rs?hIk
还有其他事情,我如何存储在我的数据库中?
我尝试用 b64 解码但不起作用。
> SHOW CREATE TABLE diagnosi;
diagnosi | CREATE TABLE `diagnosi` (
`tempId` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(30) NOT NULL,
`surname` varchar(30) NOT NULL,
`pdf` blob NOT NULL,
`gravity` varchar(50) NOT NULL,
PRIMARY KEY (`tempId`)\n) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
MySQL BLOB
数据类型的大小限制为 216 字节。 LONGBLOB
数据类型最多为 232 字节,因此将列类型从 BLOB
更改为 LONGBLOB
.
请参阅 docs 中字符串类型的存储要求。
我在 MySQL db 中存储使用 Reportlab 库制作的 PDF 文件时遇到问题。这是我的代码:
def insertIntoDb(pdfFullPath,name,surname,gravity):
print('PRIMA DEL MYSQL')
print('pdf full path'+pdfFullPath)
mydb = mysql.connector.connect(host="localhost", user="root", passwd="", database="deepface")
with open(pdfFullPath,'rb') as pdfvar:
blob = pdfvar.read()
print(blob)
sqlQuery = "INSERT INTO diagnosi(name,surname,pdf,gravity) VALUES (%s,%s,%s,%s)"
mycursor = mydb.cursor()
val = (name,surname,blob,gravity,)
mycursor.execute(sqlQuery,val)
mydb.commit()
mycursor.close()
mydb.close()
控制台显示:
mysql.connector.errors.DataError: 1406 (22001): Data too long for column 'pdf' at row 1
我已经在 mysql 配置文件中设置了最大允许数据包,但问题是当我尝试打印(我知道我不能)PDF 时,我得到了这个:
^\7:[,1qq,N_Sd$dm-:XU2/Pga=O1f/`hY7X1nrca).:_\'-4,n*"L5r,CHFpGo:"E,MDLu7EW%CFF0$Rl?jT\'6%k%,?AF%UK6ojt/c$<^Xh=;VarY:L8cQYTgj/:CfA/j1=dbU@a<:%D;rDV[)WDu)5*"98A5kkfYAqs0FFVZk[*Mb(Rs?hIk
还有其他事情,我如何存储在我的数据库中? 我尝试用 b64 解码但不起作用。
> SHOW CREATE TABLE diagnosi;
diagnosi | CREATE TABLE `diagnosi` (
`tempId` int(11) NOT NULL AUTO_INCREMENT,
`name` varchar(30) NOT NULL,
`surname` varchar(30) NOT NULL,
`pdf` blob NOT NULL,
`gravity` varchar(50) NOT NULL,
PRIMARY KEY (`tempId`)\n) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci
MySQL BLOB
数据类型的大小限制为 216 字节。 LONGBLOB
数据类型最多为 232 字节,因此将列类型从 BLOB
更改为 LONGBLOB
.
请参阅 docs 中字符串类型的存储要求。