数据库建立

USE [DB2]
GO
/****** Object:  Table [dbo].[银行表]    Script Date: 08/16/2019 09:00:15 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
SET ANSI_PADDING ON
GO
CREATE TABLE [dbo].[银行表](
    [银行代码] [nvarchar](255) NULL,
    [电话] [nvarchar](255) NULL,
    [银行名称] [varchar](100) NULL
) ON [PRIMARY]
GO
SET ANSI_PADDING OFF
GO
INSERT [dbo].[银行表] ([银行代码], [电话], [银行名称]) VALUES (N'B1100', N'010-4573', N'工商银行北京分行')
INSERT [dbo].[银行表] ([银行代码], [电话], [银行名称]) VALUES (N'B111A', N'010-3489', N'工商银行北京A支行')
INSERT [dbo].[银行表] ([银行代码], [电话], [银行名称]) VALUES (N'B111B', N'', N'工商银行北京B支行')
INSERT [dbo].[银行表] ([银行代码], [电话], [银行名称]) VALUES (N'B111C', N'010-5729', N'工商银行北京C支行')
INSERT [dbo].[银行表] ([银行代码], [电话], [银行名称]) VALUES (N'B1210', N'021-5639', N'工商银行上海分行')
INSERT [dbo].[银行表] ([银行代码], [电话], [银行名称]) VALUES (N'B121A', N'021-8759', N'工商银行上海A支行')
INSERT [dbo].[银行表] ([银行代码], [电话], [银行名称]) VALUES (N'B2100', N'010-6829', N'交通银行北京分行')
INSERT [dbo].[银行表] ([银行代码], [电话], [银行名称]) VALUES (N'B211A', N'010-9045', N'交通银行北京A支行')
INSERT [dbo].[银行表] ([银行代码], [电话], [银行名称]) VALUES (N'B211B', N'', N'交通银行北京B支行')
INSERT [dbo].[银行表] ([银行代码], [电话], [银行名称]) VALUES (N'B3200', N'021-6739', N'建设银行上海分行')
INSERT [dbo].[银行表] ([银行代码], [电话], [银行名称]) VALUES (N'B321A', N'021-9035', N'建设银行上海A分行')
INSERT [dbo].[银行表] ([银行代码], [电话], [银行名称]) VALUES (N'B321B', N'021-1111', N'建设银行上海B支行')
/****** Object:  Table [dbo].[法人表]    Script Date: 08/16/2019 09:00:15 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[法人表](
    [法人代码] [nvarchar](50) NULL,
    [法人名称] [nvarchar](50) NULL,
    [经济性质] [nvarchar](50) NULL,
    [注册资金] [int] NULL,
    [代表人] [nvarchar](50) NULL
) ON [PRIMARY]
GO
INSERT [dbo].[法人表] ([法人代码], [法人名称], [经济性质], [注册资金], [代表人]) VALUES (N'E01', N'赛纳网络有限公司', N'私营', 30, N'张雨  ')
INSERT [dbo].[法人表] ([法人代码], [法人名称], [经济性质], [注册资金], [代表人]) VALUES (N'E02', N'华顺达水泥股份有限公司', N'国营', 5300, N'王晓伟 ')
INSERT [dbo].[法人表] ([法人代码], [法人名称], [经济性质], [注册资金], [代表人]) VALUES (N'E03', N'新意企业策划中心', N'私营', 45, N'刘爽  ')
INSERT [dbo].[法人表] ([法人代码], [法人名称], [经济性质], [注册资金], [代表人]) VALUES (N'E04', N'新都美百货公司', N'国营', 2980, N'张海洋 ')
INSERT [dbo].[法人表] ([法人代码], [法人名称], [经济性质], [注册资金], [代表人]) VALUES (N'E05', N'达伊园食品有限公司', N'集体', 290, N'李一蒙 ')
INSERT [dbo].[法人表] ([法人代码], [法人名称], [经济性质], [注册资金], [代表人]) VALUES (N'E06', N'飘美广告有限公司', N'私营', 90, N'王逸凡 ')
INSERT [dbo].[法人表] ([法人代码], [法人名称], [经济性质], [注册资金], [代表人]) VALUES (N'E07', N'浦庆石化有限公司', N'国营', 6560, N'李中信 ')
INSERT [dbo].[法人表] ([法人代码], [法人名称], [经济性质], [注册资金], [代表人]) VALUES (N'E08', N'爱贝乐玩具有限公司', N'集体', 800, N'张强  ')
INSERT [dbo].[法人表] ([法人代码], [法人名称], [经济性质], [注册资金], [代表人]) VALUES (N'E09', N'洛普文具有限公司', N'集体', 600, N'李倩  ')
INSERT [dbo].[法人表] ([法人代码], [法人名称], [经济性质], [注册资金], [代表人]) VALUES (N'E10', N'莱英投资咨询有限公司', N'三资', 680, N'张晓峰 ')
/****** Object:  Table [dbo].[贷款表]    Script Date: 08/16/2019 09:00:15 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
CREATE TABLE [dbo].[贷款表](
    [法人代码] [nvarchar](255) NULL,
    [银行代码] [nvarchar](255) NULL,
    [贷款日期] [datetime] NULL,
    [贷款金额] [float] NULL,
    [贷款年限] [float] NULL
) ON [PRIMARY]
GO
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E01', N'B1100', CAST(0x00009AFE00000000 AS DateTime), 10, 15)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E01', N'B111A', CAST(0x0000962900000000 AS DateTime), 15, 20)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E01', N'B2100', CAST(0x00009BC000000000 AS DateTime), 8, 5)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E02', N'B111A', CAST(0x0000999000000000 AS DateTime), 1000, 5)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E02', N'B111B', CAST(0x00009A9B00000000 AS DateTime), 2000, 10)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E02', N'B111B', CAST(0x00009BC000000000 AS DateTime), 1500, 10)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E02', N'B211B', CAST(0x000097A500000000 AS DateTime), 1100, 5)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E02', N'B211B', CAST(0x00009AEB00000000 AS DateTime), 2000, 15)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E02', N'B3200', CAST(0x00009AB100000000 AS DateTime), 2500, 20)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E02', N'B321A', CAST(0x0000965B00000000 AS DateTime), 3000, 20)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E03', N'B3200', CAST(0x00009AB100000000 AS DateTime), 30, 5)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E03', N'B321A', CAST(0x00009BC000000000 AS DateTime), 20, 5)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E06', N'B111B', CAST(0x00009B3D00000000 AS DateTime), 320, 20)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E06', N'B211B', CAST(0x00009B7800000000 AS DateTime), 80, 10)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E07', N'B111C', CAST(0x0000999000000000 AS DateTime), 3000, 15)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E07', N'B2100', CAST(0x00009B8400000000 AS DateTime), 2000, 10)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E07', N'B211B', CAST(0x00009B3100000000 AS DateTime), 3600, 10)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E07', N'B321A', CAST(0x000095CF00000000 AS DateTime), 4000, 25)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E09', N'B111A', CAST(0x00009B8D00000000 AS DateTime), 300, 10)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E09', N'B111C', CAST(0x00009AD700000000 AS DateTime), 200, 5)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E09', N'B321A', CAST(0x0000999000000000 AS DateTime), 150, 5)
INSERT [dbo].[贷款表] ([法人代码], [银行代码], [贷款日期], [贷款金额], [贷款年限]) VALUES (N'E10', N'B111A', CAST(0x00009AD700000000 AS DateTime), 300, 10)

在银行贷款数据库中完成下面的习题。

1. 查询贷款金额在2000至4000万元之间的法人代码、银行代码、贷款日期和贷款金额。
2. 查询2009年1月1日以后贷款且贷款期限是10年的法人代码。
3. 查询贷款期限为5年、10年或15年的贷款信息。
4. 查询经济性质为“私营“的所有法人的最高注册资金、最低注册资金和平均注册资金。
5. 查询每种经济性质的法人的经济性质、最高注册资金、最低注册资金和平均注册资金。
6. 统计每个法人的法人代码和贷款总次数,要求查询结果按贷款总次数的升序排列。
7. 查询贷款次数超过3次的法人的平均贷款金额和贷款次数。
8. 统计每种经济性质贷款的法人的总数和其平均贷款金额,列出平均贷款金额前三名的经济性质、法人总数和平均贷款金额。
9. 查询贷款期限为5年、10年或15年的法人名称、银行名称、贷款日期、贷款金额和贷款期限。
10. 查询经济性质为“国营”的法人在“上海”的银行贷款的信息,列出法人名称、银行名称和贷款日期。
11. 查询与“B1100”银行在同一城市(假设银行名称的第5和第6个字符为城市名称)的其他的银行的名称。
12. 查询哪些银行没有贷过款,列出银行号和银行名称。分别用多表连接和子查询两种方式实现。
13. 查询贷过款的所有法人的名称,贷款银行名称,贷款日期,贷款金额,要求将查询结果放在一张新的永久表New_LoanT中,新表中的列名分别为:法人名称、银行名称、贷款日期和贷款金额。
14. 分别查询经济性质“国营”和“私营”的法人名称,贷款银行名称,贷款日期,贷款金额,要求将这两个查询结果合并成一个结果集,并以法人名称、银行名称、贷款日期和贷款金额作为显示列名,结果按贷款日期的升序和贷款金额的降序显示。
15. 查询经济性质为“国营”的法人在上海的银行贷款的信息,列出法人代码、银行代码和贷款日期,分别用多表连接和子查询两种方式实现。
16. 查询在“建设银行上海分行”贷过款的法人名称,分别用多表连接和子查询两种方式实现。
17. 查询在“工商银行北京A支行”贷款金额前三名(包括并列的情况)的法人的法人代码、法人名称和经济性质,分别用多表连接和子查询两种方式实现。
18. 查询在“工商银行北京B支行”贷款、且贷款金额高于此银行的平均贷款金额的法人代码、贷款日期和贷款金额。

select 法人代码,法人名称,经济性质,注册资金 from 法人表

select 银行名称,电话 from 银行表 where 银行代码='B1100'

select 法人代码,银行代码,贷款日期,贷款金额 from 贷款表 where 贷款金额 between 2000 and 4000

select 法人代码 from 贷款表 where 贷款日期>2009-01-01 and 贷款年限=10

select * from 贷款表 where 贷款年限 in(5,10,15)

select MAX(注册资金) as '最高注册资金',MIN(注册资金) as '最低注册资金', AVG(注册资金) as '平均注册资金' from 法人表 where 经济性质='私营'

select 经济性质, MAX(注册资金) as '最高注册资金',MIN(注册资金) as '最低注册资金', AVG(注册资金) as '平均注册资金' from 法人表 group by 经济性质

select 法人代码,COUNT(*) as '贷款次数' from 贷款表 group by 法人代码 order by COUNT(*) asc

select 法人代码, AVG(贷款金额) as '平均贷款金额',COUNT(*) as '贷款次数' from 贷款表 group by 法人代码 having COUNT(*)>3

select  top 3 经济性质,AVG(贷款金额) as '平均贷款金额',COUNT(*) as '贷款次数' from 贷款表 join 法人表 on 贷款表.法人代码=法人表.法人代码 group by 经济性质 order by 平均贷款金额 desc

select 法人表.法人名称,银行表.银行名称,贷款表.贷款日期,贷款表.贷款金额,贷款表.贷款年限 from 法人表,银行表,贷款表 where 贷款表.银行代码=银行表.银行代码 and 法人表.法人代码=贷款表.法人代码

select 银行名称 from 银行表 where substring(银行名称,5,2)=(select substring(银行名称,5,2) from 银行表 where 银行代码='B1100')

select 银行表.银行代码,银行名称 from 银行表 left join 贷款表 on 银行表.银行代码=贷款表.银行代码 where 贷款年限 is null

select 银行表.银行代码,银行名称 from 银行表 where 银行代码 not in(select 银行代码 from 贷款表)

create table New_LoanT( 
    select 法人表.法人名称,银行表.银行名称,贷款表.贷款日期,贷款表.贷款金额
    from 法人表,银行表,贷款表 
    where 贷款表.银行代码=银行表.银行代码 and 法人表.法人代码=贷款表.法人代码    
)

select 法人表.法人名称,银行表.银行名称,贷款表.贷款日期,贷款表.贷款金额
    from 法人表,银行表,贷款表 
    where 贷款表.银行代码=银行表.银行代码 and 法人表.法人代码=贷款表.法人代码 and 经济性质='国营'    
union
select 法人表.法人名称,银行表.银行名称,贷款表.贷款日期,贷款表.贷款金额
    from 法人表,银行表,贷款表 
    where 贷款表.银行代码=银行表.银行代码 and 法人表.法人代码=贷款表.法人代码 and 经济性质='私营'    
order by 贷款日期 asc,贷款金额 desc

select 法人表.法人代码,银行表.银行代码,贷款日期 from 法人表,贷款表,银行表 
    where 贷款表.银行代码=银行表.银行代码 
    and 法人表.法人代码=贷款表.法人代码 
    and 经济性质='国营' 
    and 银行名称 like '%上海%' 
    
select 法人代码,银行代码,贷款日期 from 贷款表 
    where 法人代码 in (select 法人代码 from 法人表 where 经济性质='国营')
    and 银行代码 in(select 银行代码 from 银行表 where 银行名称 like '%上海%')

数据库查询简单练习(五)相关推荐

  1. 用SQL语句进行数据库查询(简单查询)

    前言

  2. 实验四 数据查询——简单查询 Sql Server数据库实验

    实验四  数据查询--简单查询   一.实验目的 1.掌握SQL查询语句的基本概念  2.掌握SQLServer查询语句的基本语法 3.熟练使用SQL的Select语句对单表进行查询 4.熟练掌握并运 ...

  3. 【SQL Server】数据库开发指南(五)T-SQL 高级查询综合应用与实战

    本系列博文还在更新中,收录在专栏:#MS-SQL Server 专栏中. 本系列文章列表如下: [SQL Server] Linux 运维下对 SQL Server 进行安装.升级.回滚.卸载操作 [ ...

  4. php简单的mysql类_超简单php mysql数据库查询类

    本文章为你免费提供一款漂亮的超简单php mysql数据库查询类哦 */ class Config{ private $host;        //主机名称:一般是localhost private ...

  5. mysql数据库查询源码_超简单php mysql数据库查询类

    本文章为你免费提供一款漂亮的超简单php mysql数据库查询类哦 */ class Config{ private $host; //主机名称:一般是localhost private $root; ...

  6. php输出mysql查询结果_PHP简单获取数据库查询结果并返回JSON

    header("Content-type:text/html;charset=utf-8"); //连接数据库 $con = mysql_connect("localho ...

  7. 万能数据库查询分析器使用技巧之(十五)

    万能数据库查询分析器使用技巧之(十五) --- 6.01版本新增的SQL 执行计划功能 马根峰                    (广东联合电子服务股份有限公司, 广州 510300) 摘要    ...

  8. oracle数据库查询近五年数据,Oracle数据库查询基本数据

    ---------------------------------------------------------------- --找出EMP表 select * from EMP; --选择在部门 ...

  9. 求数学系或计算机系姓张的学生的信息,实验二数据库的简单查询和连接查询.docx...

    贵州大学实验报告 学院:计算机科学与信息学院 专业:信息安全 班级: 姓名 学号 实验组 实验时间 指导教师 成绩 实验项目名称 数据库的简单查询和连接查询 实验目的 使学生掌握SQL Server ...

最新文章

  1. 为什么面包板不能够做射频电路实验?
  2. android 实现悬架控制
  3. 【STM32H7教程】第4章 STM32H7工程模板建立(MDK5)
  4. 字符串中斜杠换行注意事项之-多余空格
  5. boost::subgraph用法的测试程序
  6. Win10 Terminal + WSL 2 安装配置指南
  7. java取模多位数_JAVA大数类—基础操作(加减乘除、取模、四舍五入、设置保留位数)...
  8. MySQL首次使用Windows_mysql的安装与使用(windows)
  9. 解决easyExcel和poi版本冲突问题
  10. apple apns http2 java调用
  11. Halcon图像预处理与形态学(图像的点运算)
  12. 《深入理解JAVA虚拟机》周志明 第三版 - 第三章 垃圾收集器与内存分配策略
  13. 剪贴板扩展windows_增强和扩展Windows剪贴板功能的最佳工具
  14. js实现文本语音播放
  15. 库存管理系统的设计与实现(代码)
  16. 王者勋章服务器维护中,【维护】4月1日官方维护公告(抢鲜服)
  17. 解决小程序canvas高清屏模糊问题
  18. IOS 图标背景是黑色
  19. (JAVA)国际跳棋--棋里乾坤
  20. Golang 安装 Gin 失败解决方案

热门文章

  1. Linux 管道通信
  2. C++中模板的特化与偏特化
  3. 常见10种安全漏洞(OWAPS TOP 10)
  4. 3D打印切片软件Cura及CuraEngine原理分析
  5. js和vue调用百度地图,实现搜索功能
  6. Oracle EBS 接收事务处理类型 rcv_transactions transaction_type
  7. 阿里云 语音通知 语音验证码 收不到 白名单
  8. 报错UnicodeDecodeError ‘gbk‘ codec can‘t decode byte 0x93 in position 7104 illegal multibyte sequence
  9. OpenGL和DirectX
  10. 【观察】戴尔科技:未来企业的创新平台,数字中国的坚实底座