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