Tuesday, December 2, 2008

Lookup field的未知错误问题zz

有个问题我一直弄不明白。关于ADO数据集控件中的Lookup类型字段,在其Lookupkeyfields属性指向的字段中存在NULL值的,就会出 现'EOleException with message '发生未知错误',这个提示。经过调试后验证只有以下3种办法可以解决:

1.把lookup字段所在的DataSet的AutoCalcField设为False
2.把lookup字段所在的DataSet的Append时给lookupkeyfield字段先赋一个值
3.把lookup字段的LookUpCache设为True(速度受到很大的影响)

象这种应该算是Delphi的bug吧?如果算是bug,为什么在delphi5到现在都没有做出修正呢?
如果不算是BUG,那种情况难道就正常吗?
希望贵公司的技术人员能给予解答,谢谢

Thursday, November 20, 2008

ADOQuery

1. ADOQuery的SQL语句的执行
select 语句用 open即可
其他语句用 EXECSQL

with ADOQuery1 do
begin
Close;
SQL.Clear;
SQL.Text:='update....';
execsql;
end;

2. SQL语句带参数
Query1.ParamByName('参数名').DataType;


3 like语句带参数

DataModule1->ADOQueryRef->Close();
DataModule1->ADOQueryRef->SQL->Clear();
DataModule1->ADOQueryRef->SQL->Add("SELECT * FROM tbRefineries WHERE rfName LIKE :par1 AND rfAddress LIKE :par2 AND rfPhone LIKE :par3");

DataModule1->ADOQueryRef->Parameters->ParamByName("par1")->Value="%"+EdtName->Text+"%";
DataModule1->ADOQueryRef->Parameters->ParamByName("par2")->Value="%"+EdtAddr->Text+"%";
DataModule1->ADOQueryRef->Parameters->ParamByName("par3")->Value=("%"+EdtPhone->Text+"%");


Wednesday, November 19, 2008

Rails部署

内容大部分来自在windows上面使用 Apache 部署Ruby On Rails,做了部分改动

首先是从网上下载windows版本的ruby,安装,记得要装gem哦。
安装rails,mongrel,和mongrel_servicegem install rails
gem install win32-service
gem install mongrel
gem install mongrel_service
准备 ROR 程序

命令行定位到程序目录
创建production数据库
rake db:migrate RAILS_ENV=production
试运行
ruby script/server

把 ROR 程序添加成windows服务
mongrel_rails service::install -N myapp -c c:\myapp -p 4000 -e production --prefix \myapp
你也可以使用mongrel_rails service::remove -N myapp 去删除他
启动该服务


配置apache的httpd.conf
安装apache,修改httpd.conf文件,取消一下三行的注释。

LoadModule proxy_module modules/mod_proxy.so LoadModule proxy_connect_module modules/mod_proxy_connect.so LoadModule proxy_http_module modules/mod_proxy_http.so

在httpd.conf最后加上proxy pass的设置
ProxyPass /myapp http://127.0.0.1:4000/myapp
ProxyPass /myapp/ http://127.0.0.1:4000/myapp/
ProxyPassReverse /myapp http://127.0.0.1:4000/

这样就可以使用http://127.0.0.1/myapp来访问了。不过有个问题(我没有出现这个问题,以下仅供参考),就是你的图片和css之类的都会因为路径问题而 无法显示。解决办法在javaeye里面看到一个,下面给出代码,还是在httpd.conf的最后添加几行代码,当然上面的proxy的要删除。
ProxyRequests Off

BalancerMember http://localhost:4000
BalancerMember http://localhost:4001



ServerName www.cpu123.com
DocumentRoot d:/sdroad/public
ProxyPass /images !
ProxyPass /stylesheets !
ProxyPass /javascripts !
ProxyPass / balancer://myCluster/
ProxyPassReverse / balancer://myCluster/
ProxyPreserveHost on