基本模式定义+

SQL支持许多不同的完整性约束。

  not null, 在该属性上不允许空值

  primary key 是否是是主码,主码必须非空且唯一

  foreign key

  check(P),P是谓词条件

Create Table instructor (ID char(5),

name varchar(20) not null,

            dept_name varchar(20),

            salary numeric(8,2),

            primary key(ID),

            check(salary>=0));

Create Table instructor (ID char(5), primary key,

name varchar(20),

            dept_name varchar(20),

            salary numeric(8,2),

            check(salary>=0));

在SQL server2000中,与WHERE子句不同的是:它能为空

Drop table instructor

Alter Table instructor add birthday,增加新的属性

Alter Table instructor drop A,去掉某些属性,不用某个属性就好,误操作引起

Alter table instructor modify(ID char(10));

SQL是具有影响力的商用市场化的关系查询语言

  数据定义语言(DDL)

  数据操纵语言(DML)

  数据控制语言(DCL)

SQL查询基本结构

  select

  from

  where

去除重复: select distinct dept_name from instructor

选择所有属性:select * from instructor;

where子句

  select name frome instructor where dept_name ='Comp.Sci' and salary>70000;

逻辑连接符:and or not <= >= ><

from 子句

找出关系instructor 和teachers 的笛卡尔积

select *

from instructor, teaches;

例子:找出Computer Science系的教师名称和课程名称

instructor(ID,name,dept_name,salary)  teaches(ID,course_id,sec_id,semester,year)

select name,course_id

from instructor, teaches

where instructor.ID = teachers.ID and instructor.dept_name = 'Comp. Sci';

【笛卡尔积】

在数学中,两个集合XY的笛卡儿积(Cartesian product),又称直积,表示为X × Y,第一个对象是X的成员而第二个对象是Y的所有可能有序对的其中一个成员。
假设集合A={a, b},集合B={0, 1, 2},则两个集合的笛卡尔积为{(a, 0), (a, 1), (a, 2), (b, 0), (b, 1), (b, 2)}。
类似的例子有,如果A表示某学校学生的集合,B表示该学校所有课程的集合,则A与B的笛卡尔积表示所有可能的选课情况。A表示所有声母的集合,B表示所有韵母的集合,那么A和B的笛卡尔积就为所有可能的汉字全拼。
 
设A,B为集合,用A中元素为第一元素,B中元素为第二元素构成有序对,所有这样的有序对组成的集合叫做A与B的笛卡尔积,记作AxB.
笛卡尔积的符号化为:
A×B={(x,y)|x∈A∧y∈B}
例如,A={a,b}, B={0,1,2},则
A×B={(a, 0), (a, 1), (a, 2), (b, 0), (b, 1), (b, 2)}
B×A={(0, a), (0, b), (1, a), (1, b), (2, a), (2, b)}

运算性质

1.对任意集合A,根据定义有
AxΦ =Φ , Φ xA=Φ
2.一般地说,笛卡尔积运算不满足交换律,即
AxB≠BxA(当A≠Φ ∧B≠Φ∧A≠B时)
3.笛卡尔积运算不满足结合律,即
(AxB)xC≠Ax(BxC)(当A≠Φ ∧B≠Φ∧C≠Φ时)
4.笛卡尔积运算对并和交运算满足分配律,即
Ax(B∪C)=(AxB)∪(AxC)
(B∪C)xA=(BxA)∪(CxA)
Ax(B∩C)=(AxB)∩(AxC)
(B∩C)xA=(BxA)∩(CxA)

SQL重命名机制

  old name as new name

    select name as instructor_name

【E】找出所有教师名,他们的工资至少比Biology系的某一个教师的工资要高:

select distinct T.name

from instructor as T,instructor as S

where T.salary >S.salary and S.dept_name = 'Biology';

字符串运算

  like的模式匹配

  百分号(%)匹配字符串通配符

  下划线(_)匹配任意一个字符

转义字符

  ‘ab\%cd%’

排序

  按照字母顺序列出在Physics习的所有老师

  select name

  from instructor

  where dept_name = 'Physics'

  order by name;//按照name字段进行排序;

升序&降序(ordered by salary desc, name asc)//如果工资相同,那么按照name字母进行升序。

集合运算

except,剔除掉

聚集函数

  平均值(avg)

  最小值(min)

  最大值(Max)

  综合(sum)

分组聚集

  group by 分组概念

  having对分组再进行选择

select avg(salary) as avg_salary

from instructor

where dept_name = 'Comp.Sci';

找出每个系的平均工资

select dept_name avg(salary) as avg_salary

from instructor

group by dept_name;

找出平均工资超过42000美元的系

select dept_name avg(salary) as avg_salary

from instructor

group by dept_name

having avg(salary) > 42000

空值

select name from instructor where salary is null;

空值的存在给聚集运算带来了麻烦,聚集函数根据以下原则处理空值

除了count *外,所有的函数都忽略空值

【数据库(一)】SQL语言-表定义、查询的更多相关文章

  1. Sybase数据库常用sql语言

    Sybase数据库常用sql语言 1,表备份: --table_name1:需要备份的表; table_name2:备份后的表 SELECT * into table_name2 from table ...

  2. 数据库系统学习(七)-SQL语言之复杂查询与视图

    第七讲 SQL语言之复杂查询与视图 基本内容 子查询 IN与NOT IN谓词子查询 判断某一表达式的值是否在子查询的结构中 非相关子查询 相关子查询 theta some /theta all谓词子查 ...

  3. MySQL入门——MySQL数据库和SQL语言

    MySQL入门——MySQL数据库和SQL语言 摘要:本文主要了解了MySQL关系型数据库和SQL语言的基本知识. MySQL数据库 简介 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB ...

  4. 架构-数据库访问-SQL语言进行连接数据库服务器-DAO:DAO

    ylbtech-架构-数据库访问-SQL语言进行连接数据库服务器-DAO:DAO DAO(Data Access Object) 数据访问对象是一个面向对象的数据库接口,它显露了 Microsoft ...

  5. 避免SQL全表模糊查询查询 下载文件时-修改文件名字

    避免SQL全表模糊查询查询   1.模糊查询效率很低: 原因:like本身效率就比较低,应该尽量避免查询条件使用like:对于like %...%(全模糊)这样的条件,是无法使用索引的,全表扫描自然效 ...

  6. 架构-数据库访问-SQL语言进行连接数据库服务器-OLE:OLE

    ylbtech-架构-数据库访问-SQL语言进行连接数据库服务器-OLE:OLE Object Linking and Embedding,对象连接与嵌入,简称OLE技术.OLE 不仅是桌面应用程序集 ...

  7. SQL多表连接查询

    SQL多表连接查询 本文主要列举两张和三张表来讲述多表连接查询. 新建两张表: 表1:student  截图如下: 表2:course  截图如下: (此时这样建表只是为了演示连接SQL语句,当然实际 ...

  8. 图解SQL多表关联查询

      图解SQL多表关联查询     网上看了篇文章关于多表连接的,感觉很好,记录下来,以便日后自己学习  内连接     左连接     右连接       全外连接   1. 查两表关联列相等的数据 ...

  9. 架构-数据库访问-SQL语言进行连接数据库服务器:SQL语言进行连接数据库服务器

    ylbtech-架构-数据库访问-SQL语言进行连接数据库服务器:SQL语言进行连接数据库服务器 数据库和应用服务器的连接. 在基于三层构架的信息系统开发中,应用服务器要利用SQL语言进行连接数据库服 ...

随机推荐

  1. DevOps的故事(如何整合开发和运维?)

    在一个与我们平行的世界中,有一个软件开发公司.这个公司所做的产品用户量近期增长的十分迅猛,但是令CTO头疼的是公司的两大部门:开发部和运维部近期也是“掐”得厉害.为解决这个问题,CTO决定倒入现在十分 ...

  2. opencv学习之路(19)、直方图

    一.概述 二.一维灰度直方图 #include "opencv2/opencv.hpp" #include<iostream> using namespace cv; ...

  3. Linux I/O 调度算法

    IO调度器的总体目标是希望让磁头能够总是往一个方向移动,移动到底了再往反方向走,这恰恰就是现实生活中的电梯模型,所以IO调度器也被叫做电梯. (elevator)而相应的算法也就被叫做电梯算法.而Li ...

  4. Python:将数组中的元素导出到变量中 (unpacking)

    问题 你需要将数组(list)或元组(tuple)中的元素导出到N个变量中. 解决方案 任何序列都可以通过简单的变量赋值方式将其元素分配到对应的变量中,唯一的要求就是变量的数量和结构需要和序列中的结构 ...

  5. Lintcode97-Maximum Depth of Binary Tree-Easy

    97. Maximum Depth of Binary Tree Given a binary tree, find its maximum depth. The maximum depth is t ...

  6. css基础参考文档

    block inline-block inline区别 absolute定位详解:https://www.jianshu.com/p/a3da5e27d22b css浮动详解 float浮动 div变 ...

  7. CentOS磁盘用完的解决办法,以及Tomcat的server.xml里无引用,但是项目仍启动的问题

    这是我2018年的第一篇博客...人真是懒了啊...最近在写微信小程序,觉得小程序做的也... 好了不吐槽了,言归正传 前言: 由于我之前不是买了个三年的香港服务器么 , 之前广州2的服务器我就没有续 ...

  8. Kotlin 条件控制

    IF 表达式 一个 if 语句包含一个布尔表达式和一条或多条语句. // 传统用法 var max = a if (a < b) max = b // 使用 else var max: Int ...

  9. App自动更新(DownloadManager下载器)

    一.开门见山 代码: object AppUpdateManager { const val APP_UPDATE_APK = "update.apk" private var b ...

  10. postman(七):运行集合,看所有请求执行结果

    当在一个collection中录好接口测试用例后,可以利用postman提供的“Run collections”功能来批量执行集合下的所有请求 点击顶部菜单中的[Runner]   或者也可以直接在想 ...