自己做取款机模拟系统每天限制取款上限问题

ljm19891118 2010-10-28 08:14:57
账户表(帐号,余额,身份证号)
交易记录(帐号,日期,金额)


上面是2张表
已知身份证号
1、怎么设定一个用户一天最多取款5000啊
2、列出改身份证号在2010.1.1到2010.2.1间的交易记录

谢谢了
...全文
102 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
「已注销」 2010-10-28
  • 打赏
  • 举报
回复
CREATE TABLE #account
(
帐号 varchar(20),
余额 decimal(10,2),
身份证号 varchar(18)
)

CREATE TABLE #deal
(
帐号 varchar(20),
日期 datetime,
金额 decimal(10,2),
交易类型 nvarchar(10) -----添加交易类型
)

insert into #account select '11111',2000,'123456789'
insert into #account select '22222',9000,'000000000'
insert into #account select '33333',3700,'111111111'


insert into #deal select '11111','2010-09-26',300,N'取款'
insert into #deal select '11111','2010-09-12',4000,N'取款'
insert into #deal select '11111','2010-09-06',1600,N'取款'
insert into #deal select '11111','2010-09-06',3200,N'存款'
insert into #deal select '22222','2010-09-06',700,N'取款'
insert into #deal select '22222','2010-09-09',3600,N'取款'
insert into #deal select '22222','2010-09-21',1800,N'取款'
insert into #deal select '33333','2010-09-26',2600,N'取款'
insert into #deal select '33333','2010-09-12',900,N'取款'
insert into #deal select '33333','2010-09-06',3100,N'取款'

select * from #account

select * from #deal

-----1、怎么设定一个用户一天最多取款5000啊
SELECT [帐号],[日期],CASE WHEN SUM([金额])>5000 THEN N'超限'
ELSE SUM([金额]) END TOTAL
FROM #DEAL
WHERE [交易类型]=N'取款'
GROUP BY [帐号],[日期]
ORDER BY [帐号]

------2、列出改身份证号在2010.1.1到2010.2.1间的交易记录
declare @beginDate datetime
declare @endDate datetime

set @beginDate='2010-09-01'
set @endDate='2010-11-01'

SELECT A.[身份证号],D.帐号,D.日期,D.金额
FROM #ACCOUNT A,#DEAL D
WHERE A.帐号=D.帐号
AND D.日期 BETWEEN @beginDate AND @endDate
王向飞 2010-10-28
  • 打赏
  • 举报
回复
select sum(b.金额) --只需判断此合计是否大于5000即可
from 账户表 as a join 交易记录 as b
on a.帐号 = b. 帐号 where a.身份证号 = @身份证号
and
日期 between convert(date,getdate()) and getdate()
ljm19891118 2010-10-28
  • 打赏
  • 举报
回复
上课去了 中午回来
ljm19891118 2010-10-28
  • 打赏
  • 举报
回复
谢谢了 但是问什么那里要加上
N'取款'
类型这是要加 但是那N是什么意思?
基本的问题都解决了
[新手练习题] 步骤1:编写程序Account.java,其中定义银行账户类Account。该类中有账号、姓名、存款余额等数据域,余额默认是0;有存款、取款、获取当前余额等方法。其中账号为长度为12位数字的字符串,姓名为字符串,存款余额为double。 步骤2:编写名为CreditAccount类的信用卡账户类。该类继承自Account类,增加一个透支限额(double)数据域,透支限额默认为1000。同时该类账户取款时允许透支,但不能超过透支限额。 步骤3:编写名为SavingAccount的储蓄账户类SavingAccount。该类继承自Account类。该类账户取款时不允许透支。 步骤4:编写名为Bank的模拟银行类,其中可以存储多个类型可能是信用卡账户或储蓄账户的对象(可以用数组或ArrayList实现)。该类包含以下方法: 开户:即增加一个新的账户,注意:不允许两个账户的账号相同 销户:即删除一个已有的账户 查询账户:根据一个账号,查询有无该账号的账户 统计目前银行的存款总余额的方法。 统计目前银行的信用卡账户总透支金额的方法。 统计目前总账户数。 统计目前信用卡账户数 统计目前储蓄卡账户数 步骤5:编写客户端类Client.java完成以下功能: 编写一个静态方法,创建一个银行对象,并随机生成10个账号从1000 0000 0000到1000 0000 0009、类型不同的账户。 main方法中模拟几次开户操作。 main方法中模拟几次销户操作。 模拟几个对指定账号的存款和取款操作。 输出银行的总账户数、总余额、总透支数、各类具体账户数。

34,594

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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