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

使用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 要操作的是那个表(注意事项:查询中不能使用*作为字段。查询多少字段,就写多少字段名称)

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

WHERE 查询条件过滤

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

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

GROUP BY 子句聚合数据函数:

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

SELECT   SalesOrderID,sum(UnitPrice) as TotalPrice FROM Sales.SalesOrderDetail Group BY SalesOrderID--聚合函数
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条代码和结果

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

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

ORDER BY 排序查询:

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

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]

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

USE  AdventureWorks  

GO

CREATE TABLE Stores
(
  StoresCode char(4) NOT NULL Primary KEY,
  Name         nvarchar(40) NOT NULL,
  Address      nvarchar(20) NULL,
  City            nvarchar(20) null,
  State          char(2)  DEFAULT(‘0‘)  NOT NULL,
  Zip              Char(5) NOT NULL
)
CREATE TABLE Sales
(
   OrderNumber Varchar(20) not null primary key,
   StoresCode     char(4)  FOREIGN KEY REFERENCES   Stores(StoresCode) not null ,
   OrderDate      datetime  default(getdate()) not null,
   Quantity         int          not null,
   Terms             Varchar(12) not  null,
   TitleID            int           not   null
)

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

INSERT INTO Stores Values(‘Test‘,‘Test Stores‘,‘China‘,‘ShenZhen‘,‘0‘,‘100000‘)

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

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

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

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

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

批量插入数据:

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

INSERT INTO .....SELECT 语句:

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

CREATE TABLE #temp
(
  ID char(4) not null,
  name  nvarchar(20) not null
)
INSERT INTO #temp

SELETE StoresCode,Name FROM Stores

SELECT * FROM #temp
--结果
--tesT       Test Store
--tes3    Test Stores
--tes5    Test Stores
--Test    Test Stores

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

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

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

DELETE 语句

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

DELETE Stores --删除所有数据
DELETE Stores WHERE StoresCode=‘test‘--删除StoresCode=‘test‘数据
时间: 2024-10-05 16:25:33

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

SQL入门经典(十) 之事务

事务是什么?事务关键在与其原子性.原子性概念是指可以把一些事情当作一个执行单元来看待.从数据库角度看待.他是指应该全部执行或者全部不执行一条或多条语句的最小组合.当处理数据时候经常确保一件事发生另一件事也随之发生.或者二件事都不发生.实际上可能达到程度是有几十件事情或者更多的事情都必须一起发生或者都不发生.来看一个一个经典事例.这个事例各大书籍讲事务都有.就是你去银行转帐给朋友.转了100元sql如下:你的帐号扣了100元,你朋友帐号加了100元.看起来很完美.其实有个BUG存在,你的帐号被扣1

SQL总结(二)连表查询

SQL总结(二)连表查询 连接查询包括合并.内连接.外连接和交叉连接,如果涉及多表查询,了解这些连接的特点很重要. 只有真正了解它们之间的区别,才能正确使用. 1.Union UNION 操作符用于合并两个或多个 SELECT 语句的结果集. UNION 运算符通过组合其他两个结果表(例如 TABLE1 和 TABLE2)并消去表中任何重复行而派生出一个结果表. 当 ALL 随 UNION 一起使用时(即 UNION ALL),不消除重复行.两种情况下,派生表的每一行不是来自 TABLE1 就是

Yii 框架里数据库操作详解-[增加、查询、更新、删除的方法 &#39;AR模式&#39;]

public function getMinLimit () {        $sql = "...";        $result = yii::app()->db->createCommand($sql);        $query = $result->queryAll();         return array (                $query [0] ['max'],         );    } $connection=Yii::

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

MongoDB数据库中,创建.查询.更新.删除操作的对象是集合. 1.查看某个数据库中有哪些集合,在此之前需要使用数据库 C:\Windows\system32>mongo MongoDB shell version: 3.2.10 connecting to: test > db test > show dbs; chengdu 0.004GB first 0.000GB local 0.000GB > use first; switched to db first > s

SQL入门经典(一)之简介

今天是我第一天开通博客,也是我的第一篇博客.以后为大家带来第一篇关于学习技术性文章,这段时间会为大家带来是SQL入门学习.希望大家坚持读下去,因为学历有限.我也是初学者.语言表达能力不好和知识点不足,我写的不好,希望大家多多包涵.主要分享给那些想学SQL一个入门教程.主要是T-SQL语言为主.学完这些内容后你基本会数据库UDF.增删改查.存储过程.视图.规则.默认值等一些常用基本用法.高级部分现在不讨论. 结构化查询语言(Structured Query Language)简称SQL(发音:/?

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

这一篇博客主要讲键的创建,约束的创建.修改对象和删除对象. 主键:主键是每行的唯一标识符,必须包含唯一值(因此不能为NULL).由于主键在关系中数据库的重要性,因此它是所有键和约束中最重要的.一个表最多可以有一个主键.很少不需要主键的表.主键声明具有唯一性.常用有identity自动增长值和GUID.主键是唯一标识值.如果客户操作一个没有主键的表.连续添加2次一样数据.你怎么删除.删除总是2条一条删除.我们接着上篇博客. 下面创建一个主键表: USE panda GO --转为panda数据库操

DataGridView连接Sql数据库 功能 查询 添加 删除 修改

using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using System.Data.SqlClient; namespace _03大项目 { public partial cla

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

一.引擎基础 1 查看系统支持的存储引擎 show engines; 2 查看表使用的存储引擎两种方法: a.show table status from database_name where name='table_name'; b.show create table table_name; 查看使用的默认引擎: show variables like 'default_storage_engine';  //MySQL5.5以后默认使用InnoDB存储引擎, 如果显示的格式不好看,可以用\

Asp.Net MVC4入门指南(9):查询详细信息和删除记录

在本教程中,您将查看自动生成的Details和Delete方法. 查询详细信息和删除记录 打开Movie控制器并查看Details方法. public ActionResult Details(int id = 0) { Movie movie = db.Movies.Find(id); if (movie == null) { return HttpNotFound(); } return View(movie); } Code First 使得您可以轻松的使用Find方法来搜索数据.一个重要