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

工作时遇到了存中文乱码的问题,存到数据库了都是问号???,直接再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

你可能感兴趣的:(C#,数据库,Oracle,C#,数据库乱码,数据库字符集)