关于Django数据库中的db.utils.OperationalError: (2026, ‘SSL connection error: unknown error number‘)

文章讲述了在高版本MySQL中SSL默认开启的问题,提出两种解决方案:一是修改my.ini文件禁用SSL,但由于权限限制未实践;二是通过安装pymysql并在Django项目中设置,将pymysql安装为MySQLdb以避免SSL问题。

原因全都是(较高版本的mysql的ssl默认是开启的),解决方案是修改mysql的配置my.ini文件,添加skip_ssl。但是因为不是自己的数据库不能随便改,所以这个方案没试过。

其他解决方案:
安装pymysql,在django的demo目录下的init文件,添加以下代码

import pymysql
pymysql.install_as_MySQLdb()

给定的参考引用中未提及解决`django.db.utils.OperationalError: unknown function: JSON_VALID()`错误的方法,不过可以根据常见的解决思路来尝试解决此问题。 `JSON_VALID()` 是一个 SQL 函数,通常用于检查一个字符串是否为有效的 JSON 格式。当 Django 抛出 `unknown function: JSON_VALID()` 错误时,意味着数据库不支持这个函数或者数据库版本过低。 ### 可能的解决方法 #### 1. 检查数据库版本 确保使用的数据库版本支持 `JSON_VALID()` 函数。例如,MySQL 5.7.8 及以上版本支持该函数。如果版本过低,需要升级数据库。 #### 2. 检查数据库连接配置 确保 Django 项目正确连接到支持 `JSON_VALID()` 函数的数据库。检查 `settings.py` 文件中的 `DATABASES` 设置: ```python DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'your_database_name', 'USER': 'your_username', 'PASSWORD': 'your_password', 'HOST': 'your_host', 'PORT': 'your_port', } } ``` #### 3. 自定义函数 如果数据库确实不支持 `JSON_VALID()` 函数,可以考虑在 Django 中自定义一个替代函数。例如: ```python from django.db.models import Func class CustomJSONValid(Func): function = 'YOUR_CUSTOM_VALIDATION_FUNCTION' # 替换为实际的验证函数 template = '%(function)s(%(expressions)s)' ``` 然后在查询中使用自定义函数: ```python from .models import YourModel from django.db.models import Q queryset = YourModel.objects.filter(CustomJSONValid('your_json_field')) ``` ### 相关问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值