sybase数据库sql带中文运行出错(odbc),除了在下人品,还有可能是什么原因?

yan63 2006-09-05 10:11:30
纯英文运行正常,带中文就出错,愚翁老爷在某帖提示在connectionstring中加上charset = iso_1,还是不行,现只好回家面壁。请各位不吝赐教,拜谢。
ps:具体的错误代码明天回单位帖出来,不知道各位有没有使用odbccommand在sybase运行sql时碰到这样的问题。
...全文
1209 25 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
25 条回复
切换为时间正序
请发表友善的回复…
发表回复
yan63 2006-09-07
  • 打赏
  • 举报
回复
up
yan63 2006-09-07
  • 打赏
  • 举报
回复
up
Knight94 2006-09-06
  • 打赏
  • 举报
回复
to 貌似解决了这个问题,在.net中将sql由encoding.default编码成encoding.ascii运行就可以了,难道sybase不懂有utf8这样的高级货吗?!!难道是我数据库utf8字符集未安装?

按照这样转,中文字符还能还原吗?
既然参数是可以的,为什么不用呢,这比你手动去转换简单多了。
yan63 2006-09-06
  • 打赏
  • 举报
回复
貌似解决了这个问题,在.net中将sql由encoding.default编码成encoding.ascii运行就可以了,难道sybase不懂有utf8这样的高级货吗?!!难道是我数据库utf8字符集未安装?还是不解。anyway人品是保住了.
附编码转换的代码,抄msdn:
/// <summary>
/// 转换现有字符的编码
/// </summary>
/// <param name="srcString">源字符串</param>
/// <param name="srcEnoding">源字符串编码类型</param>
/// <param name="desEncoding">要转换到的编码类型</param>
/// <returns>转换编码后的字符串</returns>
public string StringEncodingConvert(
string srcString,Encoding srcEnoding,Encoding desEncoding)
{

// Convert the string into a byte[].
byte[] srcBytes = srcEnoding.GetBytes(srcString);

// Perform the conversion from one encoding to the other.
byte[] desBytes = Encoding.Convert(srcEnoding, desEncoding, srcBytes);

// Convert the new byte[] into a char[] and then into a string.
// This is a slightly different approach to converting to illustrate
// the use of GetCharCount/GetChars.
char[] desChars = new char[desEncoding.GetCharCount(desBytes, 0, desBytes.Length)];
desEncoding.GetChars(desBytes, 0, desBytes.Length, desChars, 0);
string desString = new string(desChars);

// Display the strings created before and after the conversion.
return desString;

}

调用的代码:
Encoding srcEnoding = Encoding.Default;
Encoding desEncoding = Encoding.ASCII;
string cmd_asc = stringEncodingConvert(cmd1,srcEnoding,desEncoding);
OdbcCommand cmd = new OdbcCommand(cmd_asc,conn,tran);
.......

揭帖,感谢楼上诸位!!!
yan63 2006-09-06
  • 打赏
  • 举报
回复
使用参数接受中文没有问题!!!这不失为一种解决的方法。感谢愚翁!
我再找找看运行中文sql的方法,24小时内揭帖。
Knight94 2006-09-06
  • 打赏
  • 举报
回复
to 表名、字段名都是英文,
...value ('','在这里有一些中文字符'......)

用参数试试

insert yourtable(...) values( @field1, @field2,... )
yan63 2006-09-06
  • 打赏
  • 举报
回复
老爷说的是这篇《.NET通过ODBC连接Sybase数据库的一个小问题》 吧,真是吊足了胃口,打开一看“无法找到该页 您正在搜索的页面可能已经删除、更名或暂时不可用。”faint!!!我跟中国电信拼了!!!
yan63 2006-09-06
  • 打赏
  • 举报
回复
是一条简单的insert语句
表名、字段名都是英文,
...value ('','在这里有一些中文字符'......)
Knight94 2006-09-06
  • 打赏
  • 举报
回复
这有篇类似文章介绍,在sql中出现中文是有问题
参看
http://blog.aspcool.com/default.aspx?page=2
Knight94 2006-09-06
  • 打赏
  • 举报
回复
to 连接串设置charset=iso_1或是没有设置charset,连接成功,但运行中文sql都出错

sql中的中文?表名、字段名还是参数条件
yan63 2006-09-06
  • 打赏
  • 举报
回复
现在是这样:
1.除了iso_1,连接串中charset设置成其他的都报错
2.连接串设置charset=iso_1或是没有设置charset,连接成功,但运行中文sql都出错,提示:
"
{"ERROR [01004] [MERANT][ODBC Sybase ASE driver]String data translation caused data truncation.\r\nERROR [HY000] [MERANT][ODBC Sybase ASE driver][SQL Server]Unclosed quote before the character string '一些中文字符'.\n\r\nERROR [42000] [MERANT][ODBC Sybase ASE driver][SQL Server]Incorrect syntax near " '一些中文字符'.\n" }
"
yan63 2006-09-06
  • 打赏
  • 举报
回复
好的,我都试试看
Knight94 2006-09-06
  • 打赏
  • 举报
回复
例如:
UNICODE_FSS
ISO8859_1
ISO8859_2
Knight94 2006-09-06
  • 打赏
  • 举报
回复
没有道理,工具可以程序不行,那你可以参照我上面给的地址试试其他字符设置
yan63 2006-09-06
  • 打赏
  • 举报
回复
还是出错,ERROR [01000] [MERANT][ODBC Sybase ASE driver][Sybase ASE]Cannot find the requested character set in Syscharsets: name = 'GB_2312'. ERROR [01000] [MERANT][ODBC Sybase ASE driver][Sybase ASE]No conversions will be done

我的连接串:
driver=SYBASE ASE ODBC Driver;NA=server,5000;uid=sa;pwd=;Database=dbName;charset=GB_2312,是不是数据库安装的时候少了这个字符集?可我在sybase自带的sql advantage控制台运行中文sql没有问题啊
Knight94 2006-09-06
  • 打赏
  • 举报
回复
have a try!

charset=GB_2312
yan63 2006-09-06
  • 打赏
  • 举报
回复
感谢Yuna_2z(其实游戏是一艺术,而我只是身陷其中!) ( ) 帮顶和愚翁老爷的作答
在下在connectionstring中设置charset = iso_1时可正常连接数据库,设置charset = gb2312时连接出错,提示“Cannot find the requested character set in Syscharsets: name = 'gb2312'. ERROR [01000] [MERANT][ODBC Sybase ASE driver][Sybase ASE]No conversions will be done”系统无此字符集?请问如何解决?再找找看小刀的解决方法。
Knight94 2006-09-06
  • 打赏
  • 举报
回复
支持中文的charset应该是gb2312

相关资料,参看
http://www.dotnetfirebird.org/documentation/api/1.7/FirebirdSql.Data.Firebird.FbConnection.ConnectionString.html
Yuna_2z 2006-09-05
  • 打赏
  • 举报
回复
UP
yan63 2006-09-05
  • 打赏
  • 举报
回复
数据库属性文件有没有加charset=eucgb
-----------------------------------------
明天回公司查一下,sybase我是第一次做,感谢kissknife(侧身向南边) ,cctaiyang(小刀可乐) 做答。
加载更多回复(5)
资源下载链接为: https://pan.quark.cn/s/9e7ef05254f8 【久久在线FLASH系统】是一款专为久久在线网站打造的交互式Flash平台,集成了前台展示与后台管理功能,满足内容发布、管理和用户互动的需求。Flash技术曾广泛应用于网页动画和互动内容,尤其在早期互联网时代,在游戏、广告和多媒体教学等领域发挥了重要作用。该系统的核心包括以下几个关键方面: Flash技术:系统利用Flash创建动态图形、动画和交互内容,依赖Adobe Flash Player运行。其编程语言ActionScript支持面向对象开发,便于实现复杂逻辑和交互效果。 后台管理系统:作为系统的控制中心,后台支持内容上传、编辑、分类、权限设置、用户管理及数据分析,确保内容的有序更新与发布。 产品演示模块:用户可在线预览和体验产品功能,无需下载,通过交互式演示了解产品操作流程和优势。 数据库集成:系统与数据库紧密结合,用于存储Flash文件信息、用户数据及访问记录,实现高效的数据管理与检索。 安全性与优化:系统具备防止非法访问和数据泄露的安全机制,并对Flash内容进行优化,提升加载速度与用户体验。 响应式设计:尽管Flash主要用于桌面端,系统仍考虑多设备兼容性,通过响应式设计适配不同屏幕尺寸,提供一致体验。 API接口:系统支持与其他平台或服务通过API进行数据交互,如社交媒体分享、数据分析等,拓展功能边界。 用户体验:界面设计注重交互性与视觉效果,提升用户满意度和停留时间,增强平台吸引力。 版本控制:系统支持内容版本管理,便于追踪更新历史,方便内容维护与回滚。 性能监控:内置性能监控工具,实时跟踪系统负载与资源使用情况,及时发现并解决问题,保障系统稳定运行。 【久久在线FLASH系统】是一个综合性解决方案,融合了前端展示、后台管理、互动体验和数据分析等功能,体现了当时Web
资源下载链接为: https://pan.quark.cn/s/f989b9092fc5 BP神经网络轴承故障诊断系统是一种基于人工神经网络技术的智能诊断工具,专门用于识别和分析机械设备中轴承的故障情况。该系统的核心是BP神经网络(即反向传播神经网络),它能够模拟人脑的工作方式,通过学习和训练来处理复杂的非线性问题,从而对轴承的健康状态进行精准评估。 BP神经网络的基本结构由输入层、隐藏层和输出层构成。输入层接收来自传感器的信号,如振动数据或声音频率,这些信号反映了轴承的运行状态。隐藏层负责对输入数据进行特征提取和转换,将原始信号转化为更具价值的信息。输出层则输出最终的诊断结果,例如轴承是否正常、轻微磨损或严重损坏等。 在诊断过程中,数据预处理是至关重要的步骤。原始的振动或声学数据通常含有噪声,且不同传感器的数据可能缺乏可比性。因此,需要对这些数据进行滤波、归一化等处理,以提高数据质量。预处理后的数据随后被输入到BP神经网络中。在训练阶段,网络通过反向传播算法调整权重和阈值,使预测结果尽可能接近实际故障类型。这一过程利用了梯度下降法,通过计算误差梯度来更新网络参数,以最小化损失函数(通常是均方误差,用于衡量预测值与真实值之间的差异)。 BP神经网络的性能受到多种因素的影响,包括网络结构(如隐藏层的数量和每层的神经元数量)、学习率以及训练迭代次数等。优化这些参数对于提升诊断精度和速度至关重要。此外,为了验证和提升模型的泛化能力,通常采用交叉验证方法,将数据集分为训练集、验证集和测试集。其中,训练集用于训练网络,验证集用于调整网络参数,测试集则用于评估模型在未知数据上的表现。 总体而言,BP神经网络轴承故障诊断系统凭借其强大的学习和泛化能力,通过对机械设备振动和噪声数据的分析,能够实现对轴承故障的精确识别。该系统有助于提前发现设备故障隐患,减少停机时间,提高生产效率,对工业领域

111,097

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧