SQLite数据库中文乱码处理「建议收藏」

SQLite数据库中文乱码处理「建议收藏」通过SQLiteAdministrator等工具生成的数据库文件,放入到Android中,查询记录怎么也查不出来,后来发现是编码错误,SQLiteAdministrator不支持utf编码,所以存储的中文会出现乱码的情况,处理方法如下:SQLiteDatabasedb=dbHelper.getWritableDatabase();Cursorcursor

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

通过SQLite Administrator等工具生成的数据库文件,放入到Android中,查询记录怎么也查不出来,后来发现是编码错误,SQLite Administrator不支持utf编码,所以存储的中文会出现乱码的情况,处理方法如下:

SQLiteDatabase db = dbHelper.getWritableDatabase();
                Cursor cursor = db.rawQuery("select * from info where id=?", new String[]{
  
  "8332"});
                if (cursor != null && cursor.moveToFirst()) {
                    info.setText(cursor.getString(1) + "\n"
                            + new String(cursor.getBlob(2),"GBK") + "\n"
                            +  new String(cursor.getBlob(3),"GBK"));//转码处理
                    cursor.close();
                }

当然,这不能根治问题,每次查询时都要转换编码,很麻烦,可以直接把数据库转成UTF-8编码的,这样在Android系统下跑起来畅通无阻,可以使用sqlite developer工具来替代SQLite Administrator。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/197873.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 循环-15. 统计素数并求和(20)

    循环-15. 统计素数并求和(20)

    2022年2月2日
    35
  • kubernetes经典收藏[通俗易懂]

    kubernetes经典收藏[通俗易懂]kubernetes如何在Kubernetes中编写自定义控制器以图形化的方式简单介绍KubernetesIngress以图形化的方式简单介绍KubernetesService浅聊Kubernetes的各种认证策略以及适用场景基于Kubernetes的服务网格介绍如何编写一个CoreDNS插件问题Kubernetes疑难杂症排查分享:神秘的溢出与丢包…………

    2022年7月22日
    6
  • storm单机版部署

    storm单机版部署

    2021年9月11日
    45
  • springboot的自动化配置是什么_spring三种配置方式

    springboot的自动化配置是什么_spring三种配置方式一、什么是SpringBoot的自动配置?SpringBoot的最大的特点就是简化了各种xml配置内容,还记得曾经使用SSM框架时我们在spring-mybatis.xml配置了多少内容吗?数据源、连接池、会话工厂、事务管理···,而现在SpringBoot告诉你这些都不需要了,一切交给它的自动配置吧!所以现在能大概明白什么是SpringBoot的自动配置了吗?简单来说就是用注解来对一些常规的配置做默认配置,简化xml配置内容,使你的项目能够快速运行。是否对SpringBoot自动配置

    2022年8月22日
    5
  • C语言流水灯程序_51流水灯c语言程序

    C语言流水灯程序_51流水灯c语言程序0x01是数字,十六进制的数字。其结果等效于1。在数学上就是1,只不过在计算机上用2进制和十六进制较多,所以用十六进制表示。if(i&0x01)printf("奇数\n");elseprintf("偶数\n");system("pause");.0x01代表十六进制数也就是十进制数的01,&是把这些数转化为二进制数然后进行按位与运算info>>(…

    2025年6月8日
    0
  • mysql创建数据库的步骤_MySQL创建数据表

    mysql创建数据库的步骤_MySQL创建数据表MYSQL建立数据库的步骤:通过练习查询、创建数据库,并且向数据库内单个或通过txt文件批量插入数据的方法。

    2022年9月25日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号