内容简介
第1章SQL基础入门
1.1熟悉Excel的SQL语言编写环境
疑难1如何获取外部源数据
通过OLE DB接口获取外部数据源
使用Microsoft Query导入外部源数据
疑难2如何刷新导入的外部数据
刷新导入的外部数据源
疑难3在数据源移动后如何修改数据源的连接路径
根据弹出提示自动修改移动的文件路径
通过修改连接字符串来修改移动的文件路径
疑难4如何将混合类型的字段强制设置为文本字段
强制设置导入的外部数据源的字段为文本形式
SQL中的连接字符串详解
疑难5如何对外部数据进行安全设置
安全设置外部数据
1.2 SQL基础概念
疑难6如何从表中获取多列和多行
使用SQL语句获取行和列数据
什么是关系数据库中的表
一行在表中表示什么信息
一列在表中表示什么信息
疑难7如何通过唯一标识把两个表的数据连接在一起
如何理解主键标识
1.3 SQL语句入门
疑难8如何查询工作表中单列数据
使用SQL获取单列数据
什么是SELECT子句
疑难9如何查询工作表中多列数据
使用SQL语句获取多列数据
SQL列字段命名的限制
疑难10如何查询工作表中的所有列数据
如何理解SQL语句中的通配符
什么叫别名
疑难11如何使用列别名
如何使用列别名
疑难12如何使用DISTINCT查询工作表中不重复的记录
SQL语句中关键词DISTINCT的使用
疑难13如何查询百度豪华车排行榜中某日搜索量大于800的记录
SQL语句中WHERE子句的使用
疑难14如何在SQL中使用定义名称
定义名称在SQL语句中的应用
什么叫名称
疑难15 如何对学生的成绩进行降序排列
ORDER BY子句的使用
疑难16如何不借助源数据表使用SQL语句
什么情况下的SQL语句可以不使用FROM子句
疑难17如何把一条新记录添加到数据源中
INSERT INTO语句的使用
疑难18如何在Excel中更新数据
UPDATE语句的使用
疑难19如何提取带有合并单元格的数据
如何对包含合并单元格字段的工作表使用SQL语句
疑难20如何解决查询结果中有空白记录的问题
如何去除查询结果中出现的空白记录
1.4练习与思考
第2章SQL运算符使用
2.1比较运算符
疑难21如何查询报考某专业的考生
为SQL设置条件查询子句
不以第一行为起点的数据表示
等号运算符
疑难22如何查询字段值中包含双引号的数据
包含引号的数据表示
疑难23如何查询指定日期的出口数据
日期型数据表示
疑难24如何查询啤酒销量超过50kL的信息
带有括号的字段名表示方式
大于、小于等运算
疑难25如何查询某班外同学的考试成绩
不等号比较运算
2.2逻辑运算符
疑难26如何查询缺考同学的数据
NULL值的判断
疑难27如何查询同时参加两项比赛的人员名单
IN运算的妙用
NOT IN运算出现NULL值时的注意事项
疑难28如何查询2010年进入公司的员工名单
利用BETWEEN求某范围内的数据
疑难29如何查询姓“刘”的所有人员
运用LIKE进行模糊匹配
模糊匹配中不确定长度的字符表示
疑难30如何查询订单号第三、四位为指定文本的出库记录
模糊匹配中长度为1的字符表示
疑难31如何查询成绩为C以上的同学
模糊匹配中字符区间的表示
疑难32如何查询商品代号中带有数字的商品数据
模糊匹配中数字区间的表示
疑难33如何查询姓名两端没有方括号的所有员工
模糊匹配中特殊字符的表示
2.3连接运算符
疑难34如何对多个字段进行模糊查询
连接符(&)的妙用
疑难35如何查询同时满足申请租赁型经济适用房条件的人员
同时满足多个条件的查询
疑难36如何查询付款超过最后付款期限及尚未付款的客户
满足多个条件之一的查询
2.4算术运算符
疑难37如何查询语数外总分大于240分的同学名单和总成绩
字段的四则运算
日期与数字的关系和转换
疑难38如何计算员工社会保险缴纳金额
按照百分比例计算字段
Excel中数字的精度
疑难39如何根据点坐标计算距原点的距离
幂运算的妙用
2.5练习与思考
第3章SQL常见函数使用
3.1字符串函数
疑难40如何根据二代身份证号返回出生年份
四舍六入五单双的规则
MIDB函数的用法
字符与字节的关系
疑难41如何返回邮政机构所在行政区域
RIGHT函数与RIGHTB函数的区别
疑难42如何分离联系电话的区号与电话号码
LEFT函数与LEFTB函数的区别
疑难43如何替换字符串中的地名
REPLACE函数的使用
疑难44如何去除字符串首尾两侧的空格
TRIM与LTRIM、RTRIM
空格与不可见字符
疑难45如何返回字符串中某字符所在位置
INSTR函数的使用
疑难46如何比较两列数据是否相同
CBOOL函数与STRCOMP函数用法比较
疑难47如何查询有换行符字段的记录
处理换行符的方法
疑难48如何去除路径仅返回文件名
INSTRREV函数的使用
疑难49如何将英文歌曲名称转换为小写字母
STRCONV函数的使用
LCASE函数与UCASE函数的使用
3.2算术函数
疑难50如何将价格进位到角得到产品零售价
ROUND函数的使用
CINT函数的使用
疑难51如何求出阳台的圆弧长度
弧度计算说明
疑难52如何返回直角三角形斜边长度
弧度与角度的转换
SQL中可用的其他三角函数
疑难53如何将编码转换为十六进制数
HEX函数转换为十六进制的使用
二进制、八进制、十六进制介绍
进制转换方法简介
疑难54如何根据货物重量返回满载车数量
INT函数的使用
FIX函数的使用
3.3转换函数
疑难55如何统一项目起止的日期格式
CDATE函数的使用
FORMATDATETIME函数的使用
FORMAT函数将文本型日期转换为日期值
疑难56如何格式化出货量增长率
FORMATPERCENT函数的使用
FORMATNUMBER函数的使用
用ROUND函数配合“&”返回百分比
用FORMAT函数返回百分比
疑难57如何整理投票结果并返回读书数量
VAL函数返回数字
疑难58如何将数字转换为字符
CSTR函数的使用
CSTR函数与STR函数的区别
CVAR函数的使用
疑难59如何将字符转换成数字
CLNG函数的使用
CDBL函数、CSNG函数及CVAR函数用法比较
3.4其他函数
疑难60如何根据学生成绩返回等第成绩
SWITCH函数的使用
疑难61如何得到调整后的工资额
ISNULL函数的使用
ISNUMERIC函数
疑难62如何得到反转后的回文诗
STRREVERS函数的使用
疑难63如何按规定格式返回数字与文本混杂的数据
FORMAT函数返回相应格式使用
IIF函数的使用
纯小数前是否显示前导0
疑难64如何查看支出是否超出预算
CHOOSE函数的使用
疑难65如何根据二代身份证号码判断性别
用MOD函数配合IIF函数取性别
用INT+MID+ IIF函数取性别
3.5练习与思考
第4章SQL日期和时间函数使用
4.1获取日期
疑难66如何查询今天是星期几
DATE函数的使用
NOW函数的使用
WEEKDAY函数的使用
WEEKDAYNAME函数的使用
DATEPART函数的使用
关于星期的典型语句
疑难67如何用SQL语句得到当前月的剩余天数
DATEADD+DAY函数的使用
疑难68如何用SQL判断今年是平年还是闰年
DATESERIAL函数的使用
判断平年或闰年的语句
疑难69如何用SQL获取今年母亲节的日期
WEEKDAY+DATESERIAL+FORMAT函数的使用
疑难70如何用SQL计算员工的工龄工资
DATEDIFF函数的使用
疑难71如何用SQL计算食品到期日期
DATEADD函数返回到期日期
4.2格式化日期
疑难72如何将日期和时间转换为系统标准格式
利用FORMAT函数转换日期
疑难73如何获取合同签订的英文日期
利用FORMAT函数转换为英文日期
利用函数复合运用转换为英文日期
疑难74如何将日期转换为报表所需格式
获取当月总天数的技巧
4.3时间段查询
疑难75如何返回第一季度中的销售记录
DATEPART函数忽略年份获取日期所在的季度
疑难76如何提取合同即将到期的员工及最迟续订期限
利用WEEKDAY函数获取工作日信息
疑难77如何获取所有职员的星座
不同年份查询相同月份、日期所在区间
笛卡儿积的概念
疑难78如何找出销售额最高的月份
利用MONTHNAME函数获取月份的完整表示
疑难79如何查询库存中某日的出入库情况汇总
日期和时间的关系
4.4练习与思考
第5章SQL排序查询
5.1单列数据排序
疑难80如何提取某区域的销售记录并按销售额降序排列
利用ORDER BY子句对记录进行排序
SQL查询机制步骤详解
疑难81如何找出考试成绩总分前5名的同学
利用TOP谓词查询前几条记录
TOP PERCENT保留记录规律
疑难82如何查询百米赛跑项目第5~8名的运动员
伪时间排序技巧
查找排名中间的记录的技巧
TOP谓词出现重复记录的查询规律
疑难83如何将考生姓名进行随机排序
随机排序技巧
伪随机数概念
5.2多列数据排序
疑难84如何将员工名单按照多级部门进行排序
多列排序技巧及规律
疑难85如何从总分前10名中找出语文成绩最差的3名同学
在排序结果中查找指定记录的技巧
疑难86如何得到足球比赛小组赛的出线名单
指定不同排序方法的多列排序
利用数学计算方法进行多列排序
5.3练习与思考
第6章 聚合函数与分组统计
6.1聚合函数的应用
疑难87如何求某公司的总销售量及总销售额
SUM函数在SQL语句中的使用
疑难88如何求某班学生的各科平均成绩
AV G函数在SQL中的使用
疑难89如何统计订单号不重复的数目
DISTINCT+COUNT统计不重复的记录数
疑难90如何获取学生年龄的最大值及最小值
MAX函数及MIN函数在SQL语句中的使用
疑难91如何剔除最大值及最小值后求均值
SUM+MAX+MIN+COUNT函数综合使用
疑难92如何获得入网套餐终端补贴起始月份及终止月份
FIRST函数及LAST函数的使用
疑难93如何估计货运运费的标准偏差及标准差
STDEV函数及STDEVP函数的使用
疑难94如何求某组学生口语测验成绩的方差
VAR函数及VARP函数的使用
疑难95如何计算某列中空值的数目
NULL在SQL语句中的使用
疑难96如何计算不同日期的数量
COUNT+FORMAT函数的使用
6.2域聚合函数的应用
疑难97如何按商品编码统计累计销售额
DSUM函数在SQL语句中的使用
疑难98如何求每位学生得分最高两科的所有记录
DCOUNT函数在SQL语句中的使用
疑难99如何求指定条件的货款额均值
DAVG函数在SQL语句中的使用
疑难100如何查询指定条件的人员的姓名
DLOOKUP函数在SQL语句中的使用
疑难101如何求指定条件的营业厅的最高分及最低分
DMAX函数及DMIN在SQL语句中的使用
疑难102如何求指定条件的第一个值及最后一个值
DFIRST函数及DLAST在SQL语句中的使用
疑难103如何求指定条件的方差
DVAR函数及DVARP在SQL语句中的使用
疑难104如何求指定条件的标准偏差标准差
DSTDEV函数及DSTDEVP在SQL语句中的使用
6.3分组统计
疑难105如何汇总同一物品的数量及价格
GROUP BY子句的使用
疑难106如何分组汇总多列数据
使用多个分组列的GROUPBY子句
疑难107如何查询销售数量大于15台的手机品牌及销售金额
HAVING子句的使用
疑难108如何查询平均成绩大于60分同学的学号、姓名和平均成绩
使用HAVING子句提取平均成绩大于60分的记录
疑难109如何统计姓“林”的员工人数
HAVING子句结合 LEFT函数统计某姓氏的人数
疑难110如何求某车间的机器在每分钟内的平均速度
通过GROUP BY子句结合FORMAT函数对时间段进行分组
疑难111如何查询材料编号重复出现2次或2次以上的记录
GROUP BY子句+HAVING子句+WHERE子句提取重复出现2次及 2次以上的记录
疑难112如何查询只出现1次编码的记录
GROUPBY子句+HAVING子句提取只出现1次的记录
WHERE子句=1提取只出现1次的记录
疑难113如何查询“不重复且价格最低”的记录
GROUPBY子句+MIN函数获取最低单价的记录
疑难114如何计算每个得分范围内的数量
GROUP BY+IIF函数的使用
GROUP BY+CHOOSE函数的使用
GROUP BY+PARTITION函数的使用
疑难115 如何将多行的享受月份转化为一行起止的享受月份
GROUP BY+FIRST函数+LAST函数的使用
疑难116如何实现表格行列转置
TRANSFORM语句的使用
疑难117如何得到每个人的成绩表
TRANSFORM的交叉表及GROUP BY子句汇总求和
疑难118如何生成列合计的交叉表
TRANSFORM+GROUP BY子句+UNION ALL求带有小计及合计行的结果表
6.4练习与思考
第7章 连接查询
7.1内连接查询
疑难119如何查询水果所对应的颜色
一对一连接两个工作表
疑难120如何查询每条成绩表记录所对应的学生信息
公共字段连接两个工作表
疑难121如何理解连接中的多对多关系
笛卡儿积导致数据虚增的原因
疑难122如何进行两个或者两个以上表的连接
多个工作表连接
AND在多个工作表连接中的使用
疑难123如何根据测评分数给学生评定等级
使用BETWEEN AND连接工作表
疑难124如何得到各城市满意度大小比较关系图
使用大于条件连接工作表
疑难125如何进行字母之间大小的对比
通过字母大小比较连接工作表
疑难126如何处理比赛对阵表
使用行函数连接工作表
疑难127如何使用INNER JOIN连接三个表
使用INNER JOIN连接工作表
7.2外连接查询
疑难128如何使用左外连接
使用LEFT OUTER JOIN进行左连接
疑难129如何使用右外连接
使用RIGHT OUTER JOIN进行右连接
疑难130如何使用全外连接
使用全外连接
疑难131如何对超过两个或两个以上的表进行左外连接
多个工作表进行左连接
7.3连接查询的高级应用
疑难132如何把两个工作表的资料合并在一起
UNION ALL的使用
UNION ALL与UNION的区别
疑难133如何把列数不等的两个工作表合并起来
列数不等的工作表进行连接
疑难134如何查询指定条件的职工资料
剔除指定记录进行内连接
疑难135如何查询各组长管理的组员记录
内连接及WHERE子句的使用
疑难136如何获取每一户对应的户主姓名
左外连接的高级使用
疑难137如何查询所有学生的学号、姓名、选课数及总成绩
ISNULL+IIF+左外连接的使用
疑难138如何查询学过“002”和“003”课程的学生的学号、姓名
内连接+WHERE子句+GROUPBY子句+HAVING子句的综合应用
疑难139如何生成排列组合
什么叫交叉连接
疑难140如何生成0~999的数字
交叉连接生成一组数
7.4练习与思考
第8章 子查询
8.1简单子查询
疑难141如何查询销售数量大于平均销售量的数据
大于平均值的子查询
疑难142如何查询“王双”所在部门的所有员工的销售情况
带有IN的子查询
疑难143如何输出每个学生在必修表中未修的课程
带有NOT IN的子查询
疑难144如何查询选修了课程名为“大学数学”的学生学号及姓名
带有IN的子查询
疑难145如何查询出每家户口所在地不同的记录
使用EXISTS谓词进行子查询
疑难146如何查询数学成绩大于80分的学生的相关记录
使用NOT EXISTS谓词进行子查询
疑难147如何查询销售数量大于北京分公司所有产品销售数量的品种、 分公司、数量、金额
使用ALL进行子查询
疑难148如何查询高于某些店销售数量的信息
使用ANY进行子查询
疑难149如何查询两门以上不及格课程的学生姓名、学号及其平均成绩
多条件获取符合条件的学号进行子查询
疑难150如何查询大于平均年龄的员工姓名、年龄及学历
使用HAVING子句进行子查询
8.2复杂的子查询
疑难151如何返回所在系平均年龄在系平均年龄以上的教师相关信息
使用比较表达式进行子查询
疑难152如何求各城市各月销售数量之间的排名
使用1+COUNT(*)产生排名的子查询
疑难153如何对考生的成绩进行排名
使用多个1+COUNT(*)进行子查询
疑难154如何汇总各个国家获得两块以上的金牌记录
使用SUM(1)进行子查询
疑难155如何查询进价相同及进价不同的商品
结合FIRST+LAST+IN的子查询
疑难156如何实现在分类汇总行中对某字段进行计数统计
带有“总计”的综合子查询
疑难157如何统计各大区域各省份的历年项目数小计并在所在区域内进行排名
多层嵌套综合子查询
疑难158如何根据各城市销售数量给其增加自动编号列
嵌套子查询及1+COUNT(*)形成排名
8.3练习与思考
第9章SQL与数据透视表
9.1数据透视表基础
疑难159如何汇总各供应商的供货总数及总金额
“数据透视表字段列表”窗格说明
疑难160如何统计各班某科成绩的总体情况
数据透视表汇总方式介绍
疑难161如何在数据透视表中使用鼠标拖放
启用经典数据透视表布局
疑难162如何设置合并单元格标志
设置数据透视表合并单元格标志
疑难163如何添加计算字段来计算销售金额提成
数据透视表计算字段介绍
疑难164如何添加计算项获取同比值
数据透视表计算项介绍
疑难165如何按年月汇总销售额
数据透视表日期字段分组组合
疑难166如何创建年份的单页字段数据透视表
创建数据透视表自定义页字段
9.2 SQL与数据透视表
疑难167如何创建动态的数据透视表
使用SQL语句创建动态的数据透视表
疑难168如何汇总同一个工作簿中的所有数据
使用SQL语句连接同一个工作簿内所有的工作表创建动态的数据透视表
疑难169如何汇总同一个工作簿中不同区域的数据
使用SQL语句连接同一个工作簿内不同工作表中的不同区域创建数据透视表
疑难170如何汇总不同工作簿中不同工作表的数据
使用SQL语句连接不同工作簿中不同工作表的所有数据创建动态的数据透视表
疑难171如何对列数不等的工作表创建数据透视表
使用SQL语句连接列数不等的工作表创建动态的数据透视表
疑难172如何分别统计各部门不同性别、学历、职位的人数
使用SQL语句对源数据进行结构转换创建动态的数据透视表
疑难173如何创建当月销量及累计销量的数据透视表
使用SQL语句创建带有当月统计及累计的动态数据透视表
9.3练习与思考
第10章SQL和VBA
10.1 VBA基础
疑难174如何输入和修改VBA代码并保存
VBA编样环境及VBA代码的编写和运行
启用宏的工作簿在Exce12003与Exce12007及以上版本的区别
疑难175如何设置SQL所需的VBA环境
引用ADO组件设置SQL编程环境
10.2利用ADO组件进行数据库连接
疑难176如何创建数据库连接实现简单的SQL查询
利用ADO连接数据库
利用ADO执行SQL查询,并在Excel中输出结果
ADO连接不同的数据库
疑难177如何使用VBA实现多数据库查询
同时查询多个不同的数据库
疑难178如何让用户选择数据库进行查询
利用VBA选择数据库路径
Excel自定义文档属性的概念
10.3利用ADO组件进行表的操作
疑难179如何使用VBA在数据库中新建一个表
用CREATE语句新建数据表
用SQL语句新建Excel工作表
疑难180如何使用VBA删除数据库中的表
DROP语句删除表
疑难181如何使用VBA创建新的字段
新建数据表中的字段
删除数据表中的字段
疑难182如何使用VBA修改表中现有的字段类型
修改数据表中的字段名及类型
疑难183如何使用VBA将某个表复制到其他数据库中
整个数据表的复制
10.4数据操作
疑难184如何使用VBA向表中添加新的记录
INSERT INTO语句实现数据的添加
疑难185如何使用VBA将满足条件的记录添加到表中
INSERT INTO语句实现数据的批量添加
疑难186如何使用VBA修改某个特定记录
UPDATE语句实现数据的批量修改更新
UPDATE语句实现跨数据表的更新
疑难187如何使用VBA批量更新记录
DELETE语句实现数据的批量删除
数据表的删除和清空
疑难188如何使用VBA将SQL查询结果用于数据透视表
创建数据透视表的数据源
疑难189如何使用VBA获取某几行记录
用GetRows方法实现将查询结果转换为数组
记录集的指针
疑难190如何使用VBA进行多表汇总
多表的汇总查询
OpenSchema实现数据库中结构的获取
疑难191如何使用VBA进行文件的上传和下载
将SQL查询结果存放于记录集对象
AddNew实现记录的添加
附件数据类型的应用
10.5练习与思考
第11章 综合应用
11.1销售报表分析
疑难192如何获取2010年各月销售总数量及总金额
使用SQL语句对多个工作表进行分组汇总
疑难193如何获取2010年销量前10位客户各月销售数量明细表
使用SQL语句结合数据透视表获取销量前10位的客户明细
疑难194如何获取各客户在2010年各个产品分类的销售总量及销售总金额
获取各产品销售总量及销售总金额
疑难195如何获取各销售经理所负责客户的销售总量及总金额
获取各客户销售总量及销售总金额
疑难196如何获取各个区域的销售总量及销售总金额
获取各区域销售总量及销售总金额
疑难197如何汇总各业务员的销售总量及销售总金额
获取各业务员的销售总量及销售总金额
11.2利用VBA结合SQL设计微型系统
疑难198如何设计通讯录
疑难199如何设计通用汇总程序
疑难200如何设计工资管理系统