阿里云rds+django存储emoji utf8mb4(python2和python3)

2024-05-07 06:18

本文主要是介绍阿里云rds+django存储emoji utf8mb4(python2和python3),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

python2和python3情况不同,以下分别叙述。在第一章中的所有设置,第二章节不用执行

一、基础环境为python2,mysql5.6, django1.XX

1.mysql客户端,找到/etc/mysql路径下的my.cnf文件

[client]
default-character-set = utf8mb4
[mysql]
default-character-set = utf8mb4
[mysqld]
character-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_general_ci
init_connect='SET NAMES utf8mb4'

保存, service mysql restart ,检查字符集

mysql> SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collation%';

2.设置rds参数 在控制台  参数配置 中修改 character_set_server 参数为 utf8mb4。提交会自动重启(rds不会停止工作)

3.改库表编码:

ALTER DATABASE test_data_name CHARACTER SET=utf8mb4 COLLATE=utf8mb4_general_ci;

ALTER TABLE  test_table CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

4.django配置settings, DATABASES  default添加  OPTIONS': {'charset':'utf8mb4'},  

如果报错,是因为python-mysqldb包版本低于1.2.5,如实apt方式安装需要先删除:apt-get remove --purge python-mysqldb

再安装:pip install mysql-python

二、基础环境为python3,mysql8, django3.XX

1.首先不需要指定所有表为utf8mb4编码,只需要将所需表改变字符集即可,如存储微信昵称的表

ALTER TABLE  appuser CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

2.当这个model的__str__函数返回结果中包含存储存储emoji表情的字段时,会无法提交表单,例如

class AppUser:nickname = ...def __str__(self):return self.nickname #此字段含有emoji表情

admin后台会无法创建此AppUser的数据,原因在于django_admin_log为utf8编码,会报错

"Incorrect string value: '\\xF0\\x9F\\x98\\x8A' for column 'object_repr' at row 1"

此时只需要将将django_admin_log编码改为utf8mb4即可

ALTER TABLE  django_admin_log CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

3.使到RDS实例的会话连接为utf8mb4编码

django配置settings, DATABASES  default添加  OPTIONS': {'charset':'utf8mb4'},  

4.如果在获取数据时使用的requests包,务必将返回结果以utf8mb4为编码。

def method_get_api(url, query_string={}, json_loads=True):response = requests.get(url, query_string)response.encoding = 'utf8mb4' #解析emoji表情,必须加此行,否则存入数据库的数据不正确if json_loads:return json.loads(response.text)else:return response.text

 

这篇关于阿里云rds+django存储emoji utf8mb4(python2和python3)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/966551

相关文章

Redis存储的列表分页和检索的实现方法

《Redis存储的列表分页和检索的实现方法》在Redis中,列表(List)是一种有序的数据结构,通常用于存储一系列元素,由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能,... 目录一、Redis 列表的基本操作二、分页实现三、检索实现3.1 方法 1:客户端过滤3.2 方法

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

Python3中Sanic中间件的使用

《Python3中Sanic中间件的使用》Sanic框架中的中间件是一种强大的工具,本文就来介绍Python3中Sanic中间件的使用,具有一定的参考价值,感兴趣的可以了解一下... 目录Sanic 中间件的工作流程中间件的使用1. 全局中间件2. 路由中间件3. 异常处理中间件4. 异步中间件5. 优先级

使用JavaScript操作本地存储

《使用JavaScript操作本地存储》这篇文章主要为大家详细介绍了JavaScript中操作本地存储的相关知识,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以参考一下... 目录本地存储:localStorage 和 sessionStorage基本使用方法1. localStorage

Django中使用SMTP实现邮件发送功能

《Django中使用SMTP实现邮件发送功能》在Django中使用SMTP发送邮件是一个常见的需求,通常用于发送用户注册确认邮件、密码重置邮件等,下面我们来看看如何在Django中配置S... 目录1. 配置 Django 项目以使用 SMTP2. 创建 Django 应用3. 添加应用到项目设置4. 创建

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

HDFS—存储优化(纠删码)

纠删码原理 HDFS 默认情况下,一个文件有3个副本,这样提高了数据的可靠性,但也带来了2倍的冗余开销。 Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约50%左右的存储空间。 此种方式节约了空间,但是会增加 cpu 的计算。 纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。 默认只开启对 RS-6-3-1024k

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p