关于mysql读取文件整改意见

本文介绍了MySQL中读取文件的四个必要条件,并针对MySQL 5.7新增的secure-file-priv特性进行了详细解释,提供了如何修改配置以允许任意目录文件读写的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mysql读取文件先决条件

1、必须有权限读取并且文件必须完全可读
and (select count() from mysql.user)>0/ 如果结果返回正常,说明具有读写权限。
我一般直接查看权限:
select user, file_priv from mysql.user;
这里写图片描述
所使用用户的操作文件权限需为Y。
2、欲读取文件必须在服务器上

3、必须指定文件完整的路径

4、欲读取文件必须小于 max_allowed_packet

满足条件后若还是不能读取文件

这里写图片描述
则应该为mysql5.7的一个新特性:secure-file-priv
在数据库中输入:show global variables like ‘%secure%’;
这里写图片描述
value值说明了你只能从此目录下读写文件。
如果value值为NULL,就像下图
这里写图片描述
则表明不允许文件的导入导出。

修改方法

linux下:
修改/etc/mysql/mysql.conf.d/mysqld.cnf文件,在[mysqld]内加入secure_file_priv=”/”即可将数据导出到任意目录
windows下也是修改相关配置文件

import csv import mysql.connector from mysql.connector import Error from datetime import datetime import chardet # 数据库配置 DB_CONFIG = { 'host': '192.168.1.2', 'port': 3306, 'user': 'root', 'password': '123456', 'database': 'hzzy' } CSV_FILE = r'D:\桌面\杭州致优知识产权\in_sql_cs.csv' # 使用原始字符串避免转义错误 def create_table(): """创建表结构(代码保持不变)""" # ...(原有代码无需修改) def import_data(): """数据导入逻辑修复""" try: conn = mysql.connector.connect(**DB_CONFIG) cursor = conn.cursor() # 1. 检测文件编码 with open(CSV_FILE, 'rb') as f: raw_bytes = f.read() # 读取二进制内容 detected = chardet.detect(raw_bytes) encoding = detected.get('encoding', 'gb18030') # 默认使用gb18030 # 2. 用正确编码打开文件读取CSV with open(CSV_FILE, 'r', encoding=encoding, errors='ignore') as f: csv_reader = csv.DictReader(f) if not csv_reader.fieldnames: raise ValueError("CSV文件缺少列名或为空!") print("检测到列名:", csv_reader.fieldnames) # 3. 构建插入字段列表(排除in_time) db_fields = [field for field in csv_reader.fieldnames if field != 'in_time'] placeholders = ', '.join(['%s'] * len(db_fields)) columns = ', '.join(db_fields) # 4. 逐行处理数据 for row in csv_reader: processed_data = [] for field in db_fields: value = row.get(field, '') # 类型转换逻辑 if field in ['Pre_roll_price', 'Post_roll_price']: value = float(value) if value.strip() else 0.0 elif field == 'sales_volume': value = int(value) if value.strip().isdigit() else 0 elif field == 'stock_available': value = 1 if str(value).lower() in ('true', 'yes', '1') else 0 elif field == 'update_time': value = datetime.strptime(value, '%Y-%m-%d %H:%M:%S') if value else None else: value = value.strip() if value else None processed_data.append(value) # 5. 执行插入 sql = f"INSERT INTO hzzy_sj_zb ({columns}) VALUES ({placeholders})" cursor.execute(sql, processed_data) conn.commit() print(f"成功插入 {csv_reader.line_num - 1} 条记录") except Error as e: print(f"数据库错误: {e}") conn.rollback() if conn.is_connected() else None except Exception as e: print(f"运行时错误: {e}") finally: if conn.is_connected(): cursor.close() conn.close() if __name__ == "__main__": create_table() import_data() 解析上述代码,并给出问题整改后的完整代码
最新发布
03-11
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

西杭

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值