学堂 学堂 学堂公众号手机端

MySQL组合查询(转)

lewis 1年前 (2024-04-12) 阅读数 7 #技术


有的时候我们进行MySQL查询时的查找条可能并不在同一张表中,或者外部数据库中,这个时候我们就要用到组合查询。最近刚刚开始学习这个,慢慢发现 MySQL的功能真的很强大。除了组合查询,复合语句外,还有存储过程。存储过程看起来功能好像更强大,比MySQL函数要灵活的多。网上找了一些资料对自已算是一种入门学习吧。

组合查询


组合查询是指所查询得资料来源并不只有单一的表格,而是联合一个以上的

表格才能够得到结果的。

Select *

FROM table1,table2

Where table1.colum1=table2.column1

说明:

1.查询两个表格中其中 column1 值相同的资料。

2.当然两个表格相互比较的栏位,其资料形态必须相同。

3.一个复杂的查询其动用到的表格可能会很多个。

整合性的查询:

Select COUNT (*)

FROM table_name

Where column_name = xxx

说明:

查询符合条件的资料共有几笔。

Select SUM(column1)

FROM table_name

说明:

1.计算出总和,所选的栏位必须是可数的数字形态。

2.除此以外还有 AVG() 是计算平均、MAX()、MIN()计算最大最小值的整合性查询。

Select column1,AVG(column2)

FROM table_name

GROUP BY column1

HAVING AVG(column2) 〉 xxx

说明:

1.GROUP BY: 以column1 为一组计算 column2 的平均值必须和 AVG、SUM等整合性查询的关键字

一起使用。

2.HAVING : 必须和 GROUP BY 一起使用作为整合性的限制。

复合性的查询

Select *

FROM table_name1

Where EXISTS (

Select *

FROM table_name2

Where conditions )

说明:

1.Where 的 conditions 可以是另外一个的 query。

2.EXISTS 在此是指存在与否。

Select *

FROM table_name1

Where column1 IN (

Select column1

FROM table_name2

Where conditions )

说明: 

1. IN 後面接的是一个集合,表示column1 存在集合里面。

2. Select 出来的资料形态必须符合 column1。

其他查询

Select *

FROM table_name1

Where column1 LIKE ’x%’

说明:LIKE 必须和後面的’x%’ 相呼应表示以 x为开头的字串。

Select *

FROM table_name1

Where column1 IN (’xxx’,’yyy’,..)

说明:IN 後面接的是一个集合,表示column1 存在集合里面。

Select *

FROM table_name1

Where column1 BETWEEN xx AND yy

说明:BETWEEN 表示 column1 的值介於 xx 和 yy 之间。


《SQL语句的基本语法》

Select语句的完整语法为:

Select[ALL|DISTINCT|DISTINCTROW|TOP]

{*|talbe.*|[table.]field1[AS alias1][,[table.]field2[AS alias2][,…]]}

FROM tableexpression[,…][IN externaldatabase]

[Where…]

[GROUP BY…]

[HAVING…]

[ORDER BY…]

[WITH OWNERACCESS OPTION]

说明:

用中括号([])括起来的部分表示是可选的,用大括号({})括起来的部分是表示必须从中选择其中的一个。

1 FROM子句

FROM子句指定了Select语句中字段的来源。FROM子句后面是包含一个或多个的表达式(由逗号分开),其中的表达式可为单一表名称、已保存的查询或由 INNER JOIN、LEFT JOIN 或 RIGHT JOIN 得到的复合结果。如果表或查询存储在外部数据库,在IN 子句之后指明其完整路径。

例:下列SQL语句返回所有有定单的客户:

Select orderID,Customer.customerID

FROM orders Customers

Where orders.CustomerID=Customers.CustomeersID

2 ALL、DISTINCT、DISTINCTROW、TOP谓词

(1) ALL 返回满足SQL语句条件的所有记录。如果没有指明这个谓词,默认为ALL。

例:Select ALL FirstName,LastName

FROM Employees

(2) DISTINCT 如果有多个记录的选择字段的数据相同,只返回一个。

(3) DISTINCTROW 如果有重复的记录,只返回一个

(4) TOP显示查询头尾若干记录。也可返回记录的百分比,这是要用 TOP N PERCENT子句(其中N 表示百分比)

例:返回5%定货额最大的定单

Select TOP 5 PERCENT*

FROM [ order Details]

orDER BY UnitPrice*Quantity*(1-Discount) DESC

3 用 AS 子句为字段取别名

如果想为返回的列取一个新的标题,或者,经过对字段的计算或总结之后,产生了一个新的值,希望把它放到一个新的列里显示,则用AS保留。

例:返回FirstName字段取别名为NickName

Select FirstName AS NickName ,LastName ,City

FROM Employees

例:返回新的一列显示库存价值

Select ProductName ,UnitPrice ,UnitsInStock ,UnitPrice*UnitsInStock AS valueInStock

FROM Products

Where 子句指定查询条件

1 比较运算符

比较运算符 含义

= 等于

〉 大于

〈 小于

〉= 大于等于

〈= 小于等于

〈〉 不等于

!〉 不大于

!〈 不小于

例:返回96年1月的定单

Select orderID, CustomerID, orderDate

FROM orders

Where orderDate〉#1/1/96# AND orderDate〈#1/30/96#

注意:

Mcirosoft JET SQL 中,日期用‘#’定界。日期也可以用Dateval()函数来代替。在比较字符型的数据时,要加上单引号’’,尾空格在比较中被忽略。

例:

Where orderDate〉#96-1-1#

也可以表示为:

Where orderDate〉Dateval(‘1/1/96’)

使用 NOT 表达式求反。

例:查看96年1月1日以后的定单

Where Not orderDate〈=#1/1/96#

2 范围(BETWEEN 和 NOT BETWEEN)

BETWEEN …AND…运算符指定了要搜索的一个闭区间。

例:返回96年1月到96年2月的定单。

Where orderDate Between #1/1/96# And #2/1/96#

3 列表(IN ,NOT IN)

IN 运算符用来匹配列表中的任何一个值。IN子句可以代替用OR子句连接的一连串的条件。

例:要找出住在 London、Paris或Berlin的所有客户

Select CustomerID, CompanyName, ContactName, City

FROM Customers

Where City In(‘London’,’ Paris’,’ Berlin’)

4 模式匹配(LIKE)

LIKE运算符检验一个包含字符串数据的字段值是否匹配一指定模式。

LIKE运算符里使用的通配符

通配符 含义

? 任何一个单一的字符

* 任意长度的字符

# 0~9之间的单一数字

[字符列表] 在字符列表里的任一值

[!字符列表] 不在字符列表里的任一值

- 指定字符范围,两边的值分别为其上下限

例:返回邮政编码在(171)555-0000到(171)555-9999之间的客户

Select CustomerID ,CompanyName,City,Phone

FROM Customers

Where Phone Like ‘(171)555-####’

LIKE运算符的一些样式及含义

样式 含义 不符合

LIKE ‘A*’ A后跟任意长度的字符 Bc,c255

LIKE’5

’ 5*5 555

LIKE’5?5’ 5与5之间有任意一个字符 55,5wer5

LIKE’5##5’ 5235,5005 5kd5,5346

LIKE’[a-z]’ a-z间的任意一个字符 5,%

LIKE’[!0-9]’ 非0-9间的任意一个字符 0,1

LIKE’[[]’ 1,*


这里就列这么多吧,源文中还有一些别的东西: ​​http://blog.sina.com.cn/s/blog_59e7ac3c01012goh.html​​

版权声明

本文仅代表作者观点,不代表博信信息网立场。

热门