C#操作Oracle数据库中文乱码 US7ASCII字符集 (解决方案)

本文记录了在C#中遇到Oracle数据库中文乱码的解决过程。问题表现为在C#程序中存储中文时出现问号,但在PLSQL中执行相同SQL正常。解决方案包括:使用System.Data.OracleClient连接(忽略过时警告),避免使用Oracle.ManagedDataAccess.Client,确保字段类型为NVarChar,以及使用参数化SQL语句存储中文数据。
摘要由CSDN通过智能技术生成

工作时遇到了存中文乱码的问题,存到数据库了都是问号???,直接再PLSQL中执行SQL确没有问题,网上查了很多资料并没有解决,最后通过不断尝试终于解决了,分享一下。

PLSQL-帮助-支持信息,看到数据库的字符集如下

  Character Sets
  Character size: 1 byte(s)
  CharSetID: 1
  NCharSetID: 2000
  Unicode Support: True
  NLS_LANG: AMERICAN_AMERICA.US7ASCII
  NLS_CHARACTERSET: US7ASCII
  NLS_NCHAR_CHARACTERSET: AL16UTF16

经过反复踩坑,总结以下几点:

  • 数据库连接方式要用System.Data.OracleClient(会提示已过时,不过不影响使用)
  • 不能用Oracle.ManagedDataAccess.Client。
  • 数据库要存中文的字段类型要为NVarChar/NVarChar,不能为Char、VarChar等等。

编写含参的SQL语句,把中文字段放在parameter里,下边一个增的例子,删改查就请各位举一反三吧。

using System;
using System.Collections.Generic;
using System.Data.OracleClient;
using System.IO;
using System.Linq;
namespace MyTest
{
    public static class Test
    {
          public stat
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值