DELPHI盒子
!实时搜索: 盒子论坛 | 注册用户 | 修改信息 | 退出
检举帖 | 全文检索 | 关闭广告 | 捐赠
技术论坛
 用户名
 密  码
自动登陆(30天有效)
忘了密码
≡技术区≡
DELPHI技术
lazarus/fpc/Free Pascal
移动应用开发
Web应用开发
数据库专区
报表专区
网络通讯
开源项目
论坛精华贴
≡发布区≡
发布代码
发布控件
文档资料
经典工具
≡事务区≡
网站意见
盒子之家
招聘应聘
信息交换
论坛信息
最新加入: lixuan123
今日帖子: 0
在线用户: 4
导航: 论坛 -> DELPHI技术 斑竹:liumazi,sephil  
作者:
男 delphi_bird (jerychen) ★☆☆☆☆ -
普通会员
2003/8/29 14:02:38
标题:
啊,我想跳楼! 浏览:2143
加入我的收藏
楼主: 数据库中只有一个‘出生日期’字段,但是我想在DBGrid 中输出的是年龄而非出生日期,请问各位高手该怎么做啊?
我用了两个ADOQuery,两个Datasourse做成一个主从表的模式,但是显示的年龄段统统都是一个值:41。即是第一条纪录的年龄值。请问怎么改啊?
附图:
附程序:procedure TRenshi_jiluTongji.ComboBoxbaobiaoSelect(Sender: TObject);
   var year1,month1,day1,year2,month2,day2:word;
       age:integer;
begin
   with ADOQuerybaobiao do
   begin
       Close;
       SQl.Clear;
       Sql.Add('select 员工编号,姓名,性别,所在部门,');
       if ComboBoxbaobiao.Text='按用工性质统计' then
            Sql.Add('用工性质 from worker_basic_info order by 用工性质');
       if ComboBoxbaobiao.Text='按学历统计' then
            Sql.Add('文化程度 from worker_basic_info order by 文化程度');
       if ComboBoxbaobiao.Text='按专业统计' then
            Sql.Add('所学专业 from worker_basic_info order by 所学专业');
       if ComboBoxbaobiao.Text='按年龄段统计' then
            Sql.Add('出生日期 from worker_basic_info order by 出生日期');
       open;
   end;
   Query1.Sql.Add('select 员工编号,姓名,性别,所在部门,');
   if ComboBoxbaobiao.Text='按年龄段统计' then
   begin
      DecodeDate(fMMainForm.DateTimePicker1.Date, Year1, Month1, Day1);
      DecodeDate(ADOQuerybaobiao.FieldByName('出生日期').AsDateTime, Year2, Month2, Day2);
      if month1<month2 then  age:=year1-year2-1
       else age:=year1-year2;
      with Query1 do
      begin
          Close;
          SQl.Clear;
          Sql.Add('select 员工编号,姓名,性别,所在部门,:age as 年龄 from worker_basic_info order by 年龄');
          Query1.Params.ParamByName('age').Value:=age;
      end;
   end;
       if ComboBoxbaobiao.Text='按用工性质统计' then
            Query1.Sql.Add('用工性质 from worker_basic_info order by 用工性质');
       if ComboBoxbaobiao.Text='按学历统计' then
            Query1.Sql.Add('文化程度 from worker_basic_info order by 文化程度');
       if ComboBoxbaobiao.Text='按专业统计' then
            Query1.Sql.Add('所学专业 from worker_basic_info order by 所学专业');
       showmessage(Query1.Text);
      Query1.open;

end;


----------------------------------------------
chen
作者:
男 delphi_bird (jerychen) ★☆☆☆☆ -
普通会员
2003/8/29 14:03:17
1楼: 附图:
----------------------------------------------
chen
作者:
男 xwhope (烟火) ★☆☆☆☆ -
盒子活跃会员
2003/10/1 22:49:30
2楼: 你可以用:
  if 出生日期.Value > strtodate('1900-01-01') then
    年龄.value:= copy(datetostr(date() - 出生日期.Value),3, 2);

  就可以取得年龄了,不过年龄字段请用计算字段,且在CalcFields事件加入上述代码!
  如有问题请e-mail to:ptwlou@sina.com !
----------------------------------------------
-
信息
登陆以后才能回复
Copyright © 2CCC.Com 盒子论坛 v3.0.1 版权所有 页面执行80.07813毫秒 RSS