免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2816 | 回复: 8
打印 上一主题 下一主题

用mysql相当多问题。不是说开源不好,可是拜托,争争气吧 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-12-17 01:02 |只看该作者 |倒序浏览
本来系统用access数据库,没有任何问题,就是数据量大了之后,性能下降的很快,但是最起码,没有错(谢天谢地,感谢微软,感谢access,给我一个正确的结果,我已经可以叩头了。)。

后台考虑到未来发展,转移到mysql平台,结果一下子就出现了一堆问题。

1. 中文字符不支持。
这个就够我忙几个小时了,又是修改my.ini,又是修改链接字符串。总算搞好了。

2. 插入时间格式不支持
简直吐血了。在c#里,日期含有中文“上午”“下午”,由于mysql修改支持了中文,插入的时候直接报错了。
这种低级的问题超级吐血,只好在持久层自己添加一个转换。

3. 插入的中文突然丢失了一般
测试的时候,突然发现插入的中文没了一般,英文正常,字段类型是Text。再次吐血,找不到方法之后,最后只好重建数据库。

4. 插入BLOb,图片错误。
如果是字符转化为byte[],没有问题,如果是文件之类的就错。估计还是中文字符问题。
只能再次修改持久层,对byte[]进行base64加密。
吐血中!!!!!

5. 这次竟然是官方代码抛的异常!!!!我靠!!!老大,这个是谁写的啊!
TABLENAMEOS_SALESORDER
LOG:System.ArgumentOutOfRangeException: 索引和长度必须引用该字符串内的位置。
参数名: length
  在 System.String.InternalSubStringWithChecks(Int32 startIndex, Int32 length, Boolean fAlwaysCopy)
  在 MySql.Data.Types.MySqlString.MySql.Data.Types.IMySqlValue.WriteValue(MySqlStream stream, Boolean binary, Object val, Int32 length)
  在 MySql.Data.MySqlClient.MySqlParameter.Serialize(MySqlStream stream, Boolean binary)
  在 MySql.Data.MySqlClient.Statement.SerializeParameter(MySqlParameterCollection parameters, MySqlStream stream, String parmName)
  在 MySql.Data.MySqlClient.Statement.BindParameters()
  在 MySql.Data.MySqlClient.PreparableStatement.Execute()
  在 MySql.Data.MySqlClient.MySqlCommand.ExecuteReader(CommandBehavior behavior)
  在 MySql.Data.MySqlClient.MySqlCommand.ExecuteNonQuery()
  在 Pixysoft.Framework.Noebe.NoebeCommand.Execute()

救命啊。。什么原因!!!这次连debug都没有办法了。

我估计还有无数的问题在等着我。

开源啊开源,不是我刻意说你。也摆脱你争气点。我做软件也5年多,用.net从来不会被小问题阻碍,可以专心研究算法、框架。可是一搞java,一搞开源的,就无数的小问题。

比如hibernate, tmd,竟然版本升级了,连namespace都变了。 这可以说,直接使网上数以百万计的hibernate demo code, helloworld变成费码。对于初学者,这是多么沉重的打击。

比如eclipse, 无数的拥护者肯定唾骂我。但是,和vs2005比起来,我宁愿面对无数的唾骂,也要支持vs2005。eclipse是有些不错的功能,但是那个性能。。那个易用性。。。嗨。。一启动就300m内存。用个智能提示等半天假死。还有很多打包、部署、一大堆问题。不是说ant不好,可是我只是想打个包,让我写一堆xml干嘛,而且写的跟写代码一样,还分拆在不同的目录。救命。。。比看代码还累。

后来出了个所谓的maven的,说专门针对部署的,怎么怎么好。我们用起来,简直一个狗屁。只要任意一个版本变动,立刻病毒效应。立刻打包失败,而且失败的莫名其妙。我们的工程师也就1、2个人才能解决,比如修改打包配置文件版本号最后2位之类的,其他的都云里雾里。

还有java里面做界面的,不要跟我说javaswing怎么样,最后还不是IBM推出的基于c的SWT,才结束了JAVA的界面噩梦。

嗨。。。被mysql搞到把陈年老账也翻出来了。。。


补充一下,总算解决了最后一个问题:
1. 去mysql下载最新的驱动6.12。不过直接用是不行D,说签名不通过。
2. 下载源码之后,如果直接编译,还是密钥问题,不通过。
3. 新建一个项目,然后把源码copy过去编译,通过了,可是使用起来说丢失了resource。tnnd,在原项目根本找不到。
4. 用reflector反编译MySql.Data.net,找到这个Resource,导出来,放进自己的项目,修改一下名字(因为项目namespace不同了,所以要改下resource里面的名字)
5. 通过了。

论坛徽章:
0
2 [报告]
发表于 2010-12-17 07:28 |只看该作者
其实不要恨开源,恨就恨为什么还在IT这行吧。

一日还在做IT,类似的问题就还要解决,至于修复什么问题真的区别不大。

搜文档,读文档,这就是我们的日常生活

论坛徽章:
0
3 [报告]
发表于 2010-12-20 11:27 |只看该作者
本帖最后由 zang232 于 2010-12-20 11:34 编辑

你这5年,让微软毁得不轻啊~~.没有开源我们将永远是工人,我们将永远跟在微软的后面,从VC6升级到VSStudio2012..将永远给别人打工。有了开源,特别是LAMP才成就了今天的无数传奇,也使你成为传奇变成可能。单单一个成本问题,就会让无数人却步,试想有谁会有那么多钱去买Oracle.买SQLServer..买得起又哪请得起贵得要命的DBA。。开源代表着自由。。

问题多,是因为你不会用,真的,别觉得得我说得不好听。。百度、搜狐、非死不可.....谁离开mysql了?单单数据库一项的开资一年省个千八百万的应该不成问题。。

微软了不起啊,MLGB的,蓝屏都蓝到奥运会了,vista烂得要命....VS6始终是我的最爱,我找不到任何让我再升级的理由。而且我觉得gcc更可爱,用VS6的理由是因为习惯。。

论坛徽章:
0
4 [报告]
发表于 2010-12-20 17:02 |只看该作者
用eclipse? 你让我们用vi写程序的情何以堪.

你说了那么多问题,都是access到mysql的兼容性问题而已。
就像我,从mysql3转到4,字符集方面一样还是遇到问题的。但是现在新的基于5的项目,就再也不会碰到字符集的问题。

论坛徽章:
0
5 [报告]
发表于 2010-12-23 23:43 |只看该作者
lz我服了你了,赶紧找本手册看看再发贴吧

论坛徽章:
0
6 [报告]
发表于 2010-12-24 11:13 |只看该作者
用MySQL, Berkeley DB + GCC 8 年了, 现在才开始写点VB.NET的程序。 觉得现在MSDN的文档写得真差,比Visual Studio 6.0时差距那个大。

论坛徽章:
0
7 [报告]
发表于 2010-12-24 11:14 |只看该作者
本帖最后由 D700FX 于 2010-12-24 11:17 编辑

其实楼主直接转用MSSQL不更好?  Access 的好多SQL Statements MySQL都不支持。

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
8 [报告]
发表于 2010-12-25 00:47 |只看该作者
其实楼主直接转用MSSQL不更好?  Access 的好多SQL Statements MySQL都不支持。
D700FX 发表于 2010-12-24 11:14



    就是呀,楼主发什么牢骚。上面的说得实在,为何不用MSSQL,怕MS来追钱?

论坛徽章:
0
9 [报告]
发表于 2010-12-25 14:27 |只看该作者
这些问题是经常遇到的,应该都有解决的办法把只是我这些菜鸟是解决不了的
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP