使用SQL查询:

SQL查询基本语法:

SELECT [ALL|DISTINCT]  [TOP (<expression>) [PERCENT] [WITH TIES] ] <column list> [FROM <source table(s)/view>] [WHERE <restrictive condition>]

[GROUD BY<column name or expression using a column in the SELECT list>]

[HAVING <restrictive condition based  on the GROUP BY results>]

[ORDER BY <column list>]

[[FOR XML {ROW|AUTO|EXPLICIT|PATH[(<element>)]},XMLDATA][,ELEMENTS][,BINARY base 64]]

[OPTION (<query hint>,[,.....n])]

上面sql语句看起来很复杂。现在大家一一讲解。

SELECT 告诉sql执行什么操作。FROM 要操作的是那个表(注意事项:查询中不能使用*作为字段。查询多少字段,就写多少字段名称)

  1. SELECT * FROM Person.Contact --我要在Person.Contact这个表查询

WHERE 查询条件过滤

  1. SELECT * FROM Person.Contact WHERE FirstName like 'M%'--我要在Person.Contact这个表下查找是FirstName 开头为M的联系人

WHERE字句中可用的运算符如下:

GROUP BY 子句聚合数据函数:

做为BOSS要想知道每件商品的销售量和总价格。就要使用聚合函数

  1. SELECT SalesOrderID,sum(UnitPrice) as TotalPrice FROM Sales.SalesOrderDetail Group BY SalesOrderID--聚合函数
  2. SELECT SalesOrderID,sum(UnitPrice) as TotalPrice FROM Sales.SalesOrderDetail Group BY SalesOrderID having sum(UnitPrice) >10000

注意事项:过滤掉销售额小于10000的商品。不知道为什么TotalPrice 不能作为聚合函数的过滤。只能用 sum(UnitPrice) 过滤.可以在聚合函数前使用where过滤。where过滤不能使用聚合函数。容易错误点:group by 后面使用where过滤。GROUP by 只能用having过滤。having 过滤等聚合函数填充完毕后才能过滤。

聚合函数有:COUNT()求个数 SUM()求和  AVG()求平均数 MIN()最小值 MAX()最大值这些是比较常用的聚合函数,可以单独使用,也可以和group by使用。

现在介绍COUNT()聚合函数 :先看2条代码和结果

  1. select count(1) from Person.Contact --结果19972条数据
  2. select count(MiddleName) from Person.Contact --11473条数据

上面2条数据结果不一样,这个不用当心。后面博客会说这个问题(建议不要带列名作为count聚合函数)

ORDER BY 排序查询:

BOSS要求看那个商品销售前10名:这里也把TOP这个关键词介绍了。order by 那个字段DESC 按照那个字段降序排,asc升序排。top取前面多少条数据

  1. SELECT TOP 10 SalesOrderID,sum(UnitPrice) as TotalPrice FROM Sales.SalesOrderDetail Group BY SalesOrderID having sum(UnitPrice) >10000 ORDER BY TotalPrice DESC --按照销售额从高到底排序前10名数据

DISTINCT 和ALL的谓词:如果数据库有100条一样数据。 ALL是全部加载一样数据100次。DISTINCT只加载一条数据。其余99条舍弃掉。

FOR XML这里不做介绍了。后面有专门博客介绍这个查询。

INSERT 添加数据

基本语法:INSERT [TOP (<expression> )[PERCENT] [INTO] <table object>[(<column listt>)][OUTPUT <output clause>] {VALUES(<data value>)[,(datavalues)][,....n]|<table source>|EXEC <procedure>|DEFAULT VALUES}

上面语法是不是看起来很复杂,简化语法:INSERT INTO<tables object>[(<column list>)] VALUES(<data value>)[,(datavalues)][,....n]

为了下面的学习我们建立数据表:

  1. USE AdventureWorks
  2.  
  3. GO
  4.  
  5. CREATE TABLE Stores
  6. (
  7. StoresCode char(4) NOT NULL Primary KEY,
  8. Name nvarchar(40) NOT NULL,
  9. Address nvarchar(20) NULL,
  10. City nvarchar(20) null,
  11. State char(2) DEFAULT('0') NOT NULL,
  12. Zip Char(5) NOT NULL
  13. )
  14. CREATE TABLE Sales
  15. (
  16. OrderNumber Varchar(20) not null primary key,
  17. StoresCode char(4) FOREIGN KEY REFERENCES Stores(StoresCode) not null ,
  18. OrderDate datetime default(getdate()) not null,
  19. Quantity int not null,
  20. Terms Varchar(12) not null,
  21. TitleID int not null
  22. )

试一试:插入一条数据(可以直接后面写要添加数据要与数据表的列名相对应)

  1. INSERT INTO Stores Values('Test','Test Stores','China','ShenZhen','0','100000')

第一次插入值正确第二次错误:违反了 PRIMARY KEY 约束 'PK__Stores__6F4A8121'。不能在对象 'dbo.Stores' 中插入重复键。后面博客会专门讲键和约束。

我在对插入一条数据做下修改:

  1. INSERT INTO Stores(StoresCode,Name,City,Zip)Values('tes2','Test Store', 'Here','10000')

可以注意到插入SQL语句:少了address,state 插入,列设置为NULL值可以忽略提供该列的值。如果列不能设置null。则必须为下面3个条件之一,否则系统会提示错误。INSERT 终止命令被拒绝执行。

1.列定义默认值,默认值是未提供插入值会自动插入一个常量值。(后面键与默认值会说这个问题)2.列定义为接受某种形式系统生成值,最常用的生成值是为IDENTITY值。3插入数据已经提供该列的值。

批量插入数据:

  1. INSERT INTO Stores(StoresCode,Name,City,Zip)
  2. VALUES('tes5','Test Stores','bj','10000'),
  3. ('tes4','Test Stores','bj','10000');
  4. --(2 行受影响)这是sql server 2008数据库添加新功能

INSERT INTO .....SELECT 语句:

语法:INSERT INTO <table_name>[column list] <select statement>

  1. CREATE TABLE #temp
  2. (
  3. ID char(4) not null,
  4. name nvarchar(20) not null
  5. )
  6. INSERT INTO #temp
  7.  
  8. SELETE StoresCode,Name FROM Stores
  9.  
  10. SELECT * FROM #temp
  11. --结果
  12. --tesT Test Store
  13. --tes3 Test Stores
  14. --tes5 Test Stores
  15. --Test Test Stores

 UPDATE 语句更改获取得到的数据

语法:UPDATE <table name> SET <column>=<value>[,column=value] [FROM <source tables>] [WHERE <restrictive condition> ]

  1. UPDATE Stores SET State='1' --4条受影响(成功更新了4条数据)
  2. UPDATE Stores SET State='0' WHERE StoresCOde='tes2' --1条受影响

DELETE 语句

删除语句非常简单,语法:DELETE <table name>  [WHERE < condition> ]

  1. DELETE Stores --删除所有数据
  2. DELETE Stores WHERE StoresCode='test'--删除StoresCode='test'数据

SQL入门经典(二) 之数据库基本查询、添加、更新和删除的更多相关文章

  1. SQL入门经典(十) 之事务

    事务是什么?事务关键在与其原子性.原子性概念是指可以把一些事情当作一个执行单元来看待.从数据库角度看待.他是指应该全部执行或者全部不执行一条或多条语句的最小组合.当处理数据时候经常确保一件事发生另一件 ...

  2. 《SQL入门经典》总结

    <SQL入门经典>这本书从考试前就开了个头,一直到前两天才看完,拉的战线也够长的.放假来了,基本上什么内容都不记得了.好不容易看完了,就赶紧总结一下吧! 该书分为两大部分,第一部分是第1~ ...

  3. SQL总结(二)连表查询

    ---恢复内容开始--- SQL总结(二)连表查询 连接查询包括合并.内连接.外连接和交叉连接,如果涉及多表查询,了解这些连接的特点很重要. 只有真正了解它们之间的区别,才能正确使用. 1.Union ...

  4. MongoDB 的创建、查询、更新、删除

    MongoDB数据库中,创建.查询.更新.删除操作的对象是集合. 1.查看某个数据库中有哪些集合,在此之前需要使用数据库 C:\Windows\system32>mongo MongoDB sh ...

  5. 返璞归真 asp.net mvc (1) - 添加、查询、更新和删除的 Demo

    原文:返璞归真 asp.net mvc (1) - 添加.查询.更新和删除的 Demo [索引页] [源码下载] 返璞归真 asp.net mvc (1) - 添加.查询.更新和删除的 Demo 作者 ...

  6. SQL入门经典(一)之简介

    今天是我第一天开通博客,也是我的第一篇博客.以后为大家带来第一篇关于学习技术性文章,这段时间会为大家带来是SQL入门学习.希望大家坚持读下去,因为学历有限.我也是初学者.语言表达能力不好和知识点不足, ...

  7. sql 入门经典(第五版) Ryan Stephens 学习笔记 后续——存储引擎

    一.引擎基础 1 查看系统支持的存储引擎 show engines; 2 查看表使用的存储引擎两种方法: a.show table status from database_name where na ...

  8. SQL入门经典(五) 之键和约束

    这一篇博客主要讲键的创建,约束的创建.修改对象和删除对象. 主键:主键是每行的唯一标识符,必须包含唯一值(因此不能为NULL).由于主键在关系中数据库的重要性,因此它是所有键和约束中最重要的.一个表最 ...

  9. MongoDB快速入门(二)- 数据库

    创建数据库 MongoDB use DATABASE_NAME 用于创建数据库.该命令如果数据库不存在,将创建一个新的数据库, 否则将返回现有的数据库. 语法 use DATABASE语句的基本语法如 ...

随机推荐

  1. js常用方法

    若未声明,则都是js的方法 1.indexOf indexOf(str):默认返回字符串中第一次出现索引位置 的下标,没有则返回-1 indexOf(str,position):返回从position ...

  2. 【Lua】Lua的几点优化原则

    Lua是一门以性能著称的脚本语言,被广泛的应用在很多方面,比如很多游戏的插件. 很多时候,没有必要去考虑性能的问题,不过,如果我们在开始编写代码的时候就以更适当,性能更高的方式与结构去组织代码,对于程 ...

  3. 漫谈Linux内核哈希表(1)

    关于哈希表,在内核里设计两个很重要的数据结构:    哈希链表节点: 点击(此处)折叠或打开 .x [include/linux/types.h]*/ struct hlist_node { stru ...

  4. [python] 创建临时文件-tempfile模块

    This module generates temporary files and directories. It works on all supported platforms.In versio ...

  5. linux挂载数据盘

    http://jingyan.baidu.com/article/90808022d2e9a3fd91c80fe9.html

  6. PMI列子1

    遍历得到PMI中,是注释类型的,你可以参考一下.int num_text, thetype, thesubtype;tag_t  draft_aid_tag = NULL_TAG;UF_UI_open ...

  7. 【温故Delphi】Win32API之GetTempFileName

    所遇问题 新建的算量工程文件暂时保存到临时文件中,代码中调用了Win32 API——GetTempFileName 但在一台笔记本上,函数返回了一个空字符串! 为了查明原因想到了好用的GetLastE ...

  8. 慕课网Java高并发秒杀学习

    课程地址:http://www.imooc.com/learn/587 一个很好:spring,springMVC,mybatis,bootstrap,jQuery,mysql,Restful学习案例 ...

  9. 51nod 1428 活动安排问题(优先队列)

    1428 活动安排问题 首先按照开始时间从小到大排序. 其实只要维护一个结束时间的最小堆,每次比较开始时间和堆中最小时间的大小,如果比它大就放入堆中并且时间就要变成当前任务的结束时间, 否则就要新开一 ...

  10. Mac OS X 访问 Windows 共享文件夹

    Mac OS X 访问 Windows 共享文件夹 mac没有网络邻居,但可以使用finder访问局域网中windows共享的文件 1.点击 Finder 前往菜单中的「前往服务器」(或快捷键 com ...