1.Select的基本语法
Select col1,col2.....coln
[into newTable] '将查到的数据插入到新表中
[From tab1,tab2....tab3] '目标表
[where @condition] '查询条件
[Group by col1,col2....coln] '按指定列分组
[Having @condition] '在使用函数(Avg,Count)时使用having
[Order by col1,col2.....coln] '按指定的列排序
* 列(col)可以是表中的所有列,也可以是派生的列(有数个表列运算后产生的列)
* 新的表 在select 命令中被选择的数据库的表。
* 条件 数据选择时的筛选条件,你可以设定大于,小于或等于基本判断条件。
*Order by Group by 当选定要选择的列和条件后,可以对选取的数据进行排序和分组
*Having 通常和Group by 搭配使用,用来当做条件选择,就象Where条件一样。
2 基本查询
2-1 选取全部的数据 Select * from table
2-2 选取指定列 Select col from table
2-3 选取不重复的 Select
distinct col from table
2-4 指定某一列的显示格式 Select emp_Name ,Convert(char(8),birthDay,11)---将birthDay字段显示为char形式
2-5 数据排序 Select emp_Name from employee Order by emp_Name DESC | ASC -----Desc为降序,Asc为升序,默 认为升序
2-6 使用函数 Select Count(*) from sales where tot_amt >5000 ---定单金额大于5000的行数
2-7选取前几行数据 Select Top 10 OrderId from Oders
2-8 数据分组
可以利用Group by 子句对Select 命令所选取得到的数据做分组,分组后的数据可显示出来,或是利用
Sum(),Avg()等函数针对特定的列计算每组数据总和或平均值。
Select col1 ,col2
form tab
group by col1
在group by 子句中的字段必须是在Select 中出现的,例如
Select pro_id, Sum(qty*unit_price) as tot_amt
form sailes ----显示产品销售明细表中的每个产品的订贷金额总和,
group by pro_id -----并按从大到小排序
order by tot_amt DESC
Select pro_id ,Count(*) From stock
group by prod_id ----Group by 子句经常和Having搭配,用来找出
Having Count(*)>1 -----每一个组中满足指定条件的数据。该命令显示同一型号产品有两家
order by Prod_id ------以上的供应商
3 加上选择条件 当你只想选取表的部分数据时可以加上选择条件,也就是加上WHERE子句
逻辑运算符 等于 = ,不等于 <> 或 != ,大于 > ,小于<,大于等于 >=,小于等于 <= ,介于 Between ,
不介于 Not Between , In (Not In) 列值是否存在于所列的清单内,Is null 列值是否为Null
4 使用统配符
% 零个或多个字符
_ 单一任何字符
/ 特殊字符
[] 在某一范围内的字符,如[0-9] 或[acfk]
[^] 不在某一范围内的字符,如[^0-9] 或[^acfk]
注意:当使用统配符来比较数据时,由于在这种情况下SQL SERVER 无法使用主键值和索引加快数据的查询
而是一个一个的查询。
5 表的Join
在多个表之间查询时就要对多个表进行Jion查询
如: select * from stock
join product
on stock.prod_id =product.prod_id
join 两个以上的表,在stock ,product我们显示了产品的中文名称,也希望把供应商的名字显示出来。
那就必须将供应商表(supplier)也拉过来一起做join
select product.prod_name,supplier.sup_name,stock.stk_qty
From stock
Join product on stock.prod_id = product.prod_id
Join supplier on stock.sup_id = supplier.sup_id
Select A.emp_no ,A.emp_name,B.emp_no,B.emp_name,A.date_hired
From employee A
Join employee B
On (A.emp_no!=B.emp_no and A.emp_name>B.emp_name and A.date_hired >B.date_hired)
Order by A.date_hired
Out Join
Join 的结果是由两个或两个以上的表组合挑出合乎Join条件的数据。但是来自不同表的数据无法满足Join
条件则丢弃,通常我们将这种叫inner join.
另外一种叫out join ,这种方式的表有主从之分。他的处理方式是用主表的每行数据去match从属表的列,
合乎条件和不合乎条件的都是我们得到的数据,只是不合乎条件的数据会被以null填上.