delphi嵌套SQL语句。请详细讲解一下。

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了delphi嵌套SQL语句。请详细讲解一下。相关的知识,希望对你有一定的参考价值。

参考技术A add('') 里面都是SQL语句,
+scph+ ---scph是string类型的变量
就是from () d----d就是表名即给()里的临时表一个名字
参考技术B 很简单的, 吧add后面 括号内的 第一个引号和最后一个引号都去掉。组合起来不就是这个SQL吗?
d是别名追问

planqty/1000) as PlanQty 是做了一个除法吗?

参考技术C 是要解释下那些引号吗?
总之一句话,所有拼接的sql语句串前后的单引号去掉,中间的两个单引号是一个。
如'select seq,(planqty/1000) as PlanQty,isnull(qty,0) as Qty'--->select .....

'where scph = '''+scph+''''---->where scph = 'xxxx'

如果通过上面的操作后,语句在数据库中能执行,那就是正确的。追问

+scph+ , 加号是什么意思? 它下面那句的)d, 是什么意思?

追答

+scph+中的加号是拼字符串,delphi中两个字符串连接为一个字符串。
)d 是从括号中的查询结果再进行查询,查询结果定义一个别名为d

本回答被提问者和网友采纳

一文讲懂SQL子查询

参考技术A

大家好,我是宁一。


今天讲解SQL教程第18课:子查询。


SQL语句可以嵌套,最常见的就是查询语句的嵌套。


基本语法:



我们一般称外面嵌套的语句为主查询,里面被嵌套的语句为子查询,有时也会叫外查询、内查询,大家知道意思就好。


子查询要用括号括起来。子查询不仅可以放在WHERE的后面,还可以放在SELECT、FROM的后面,我们一个个来讲解。


1、子查询+WHERE子句


SQL执行时,会先执行括号内的子查询,子查询最常与WHERE子句结合使用。子查询的结果作为WHERE子句的筛选条件,完成更复杂的数据检索。


实例: 在Students表中,找出所有在"宁一"后面出生的学生。



实例解析: 需要先确定"宁一"的生日,再将生日作为WHERE筛选条件,得到最终数据。


第一步:找到"宁一"的生日




第二步:将生日作为WHERE筛选条件,得到最终数据,子查询语句要用括号括起来。






SELECT语句的子查询经常与聚合函数结合使用。因为我们使用聚合函数的时候,记录会合成一条,其它数据细节就不能显示了。


比如: 我们想要查看学生表中所有的学生姓名、学生生日、学生的最大生日。


示例结果:



错误写法:



像上面这样写是会报错的,因为聚合函数与其他表中的列(Sname,Sage),同时放在SELECT的后面。需要用GROUP BY语句将这些表中的列(Sname,Sage)分组。


上面的语句后面加上 GROUP BY Sname,Sage 就可以了。


但是这样写,会将每组的数据聚合成1条数据,比如每组有3条数据,使用聚合函数MAX()+GROUP BY,最终每组只会显示1条最大值的数据。


我们需要展现Students表中所有的学生,这样写不能满足我们的需求。


正确写法: 结合子查询来实现。




子查询与FROM子句结合使用,子查询结果被当成了一个“表”,可以用SELECT语句做进一步的筛查。


比如:我们先写一个SELECT查询语句




将上面的查询语句放在FROM的后面,则上面查询到的结果,就会被当成一个“表”。



这里有一个特别要注意的地方,放在FROM后面的子查询,必须要加别名。



复杂的子查询再嵌套进 FROM 里会让整个查询看起来过于复杂,我们一般会将子查询结果储存为视图,然后再直接使用视图作为来源表,视图会SQL高阶课程中详细讲解。


其实子查询就是查询语句嵌套,没有什么新的东西,只是多了一个层级,由内向外地一层层梳理就会很清楚了。


作业: 结合Students表,从Teachers表中找出当班主任的老师(通过子查询实现)。



作业解析: 先从Students表中,找出所有班主任的Tid并去重,将查询结果作为筛选条件,放在WHERE语句中。



以上是关于delphi嵌套SQL语句。请详细讲解一下。的主要内容,如果未能解决你的问题,请参考以下文章

delphi中adoquery的使用(delphi高手详细说一下)

数据库的SQL语句中,嵌套查询和连接查询有啥区别,说的详细的

一文讲懂SQL子查询

SQL嵌套SELECT语句的用法-

SQL语句中

sql语句中嵌套时候用in 和=有啥区别