--使用数据库
use date
go --创建表班级表
create table classInfo
(
classNo int primary key identity(1,1),--主键约束使用primary key identity
className varchar(10) not null--非空约束
)
go
--创建学员表
create table stuInfo --标识列约束使用identity
(
stuNo int primary key identity(1,1),--主键约束要求主键数据唯一并且不允许为空
stuname varchar(10)not null unique,--唯一约束使用unique关键字允许为空,但只能出现一个空值
age int check(age>10 and age<100),--检查约束使用check设置年龄
sex nchar(1)default'男',--默认约束
class int foreign key references classInfo(classNo)--外键约束用于两表之间建立关系,需要指定引用主表的那一列 )
go
--插入数据
insert into classInfo values('S2S147'),('S2S148')
insert into stuInfo values
('田七',18,'女',null),
('张三',38,'女',null),
('王五',20,'女',null),
('赵六',30,'男',null) --修改表中的数据
update stuInfo set class=1
--删除表中的数据
delete stuInfo where stuNo=1 --修改朱茂深的年龄和性别
update stuInfo set age=18,sex='男'where stuname='张三' --查询表中的数据
select * from stuInfo
select * from classInfo --查询性别为女的数据
select * from stuInfo where sex='女' --模糊查询使用like --查询'朱'字开头的名字
select * from stuInfo where stuname like '张%' --查询年龄18到20之间的数据
select * from stuInfo where age=18 or age=20
--使用in的效果一样
select * from stuInfo where age in(18,20)
select * from stuInfo where age between 18 and 20
--查询姓名年龄
select '姓名'=stuname,'年龄'=age from stuInfo where age between 18 and 20 --查询男生的人数(使用聚合函数)
select count(*) as 人数 from stuInfo where sex='男' --sum(求和)、avg(平均值)、max(最大值)、min(最小值)、count(计算总数) --查询男生女生分别多少人(分组)(group by 统计函数联合使用)
select 性别=sex, 人数=count(*) from stuInfo group by sex
--查询年龄18到20之间的个数大于等于2的数
select 性别=sex, 人数=count(*) from stuInfo
where age in (18,20) group by sex
having COUNT(*)>=2 --order by(作用是升降序 (ASC升从小到大排列)(Desc降)从大到小排列)
select * from stuInfo order by age asc
select * from stuInfo order by age desc --使用top查询前三条数据
--查询降序后的三条数据
select top 3 * from stuInfo order by age desc --查询出男生的 姓名 年龄 性别
select 姓名=stuname,年龄=age,性别=sex
from stuInfo,classInfo
where stuInfo.class=classInfo.classNo and sex='男' --内链接查询
--查询 姓名 年龄 性别 班级
select 姓名=stuname,年龄=age,性别=sex,班级=className
from stuInfo inner join classInfo
on stuInfo.class=classInfo.classNo
where sex='男' --左外连接查询使用(left join)
select stuname,age,sex,className
from stuInfo left join classInfo
on stuInfo.class=classInfo.classNo --右外连接查询 使用(right join)如果不满足条件的则返回null(空值)
select stuname,age,sex,classname
from stuInfo right join classInfo
on stuInfo.class=classInfo.classNo --全外连接查询使用(full outer join)outer可以不写
select stuname,age,sex,classname
from stuInfo full join classInfo
on stuInfo.class=classInfo.classNo --交叉链接查询(笛卡尔积)就是查询所指定要查询的值
select stuname,age,sex,classname
from stuInfo cross join classInfo --自连接查询查询张三所在班级的所有学员信息
select
姓名=s1.stuname ,
年龄=s1.age,
性别=s1.sex
from stuInfo s1,stuInfo s2
where s1.class=s2.class
and s2.stuname='张三' select
姓名=s1.stuname,
年龄=s1.age,
性别=s1.sex,
班级=c3 .className
from stuInfo s1, stuInfo s2 ,classInfo c3
where s1.class=s2.class
and s2.stuname='张三'
and s1.class=c3.classNo --子查询
select
姓名=stuname,
年龄=age,
性别=sex,
班级=class
from stuInfo
where class=(select class from stuInfo where stuname='张三') select
姓名=stuname,
年龄=age,
性别=sex,
班级=(select classname from classInfo where classNo=class)
from stuInfo
where class=
(select class from stuInfo where stuname='张三')

SQL 基本查询语句的更多相关文章

  1. SQL逻辑查询语句执行顺序 需要重新整理

    一.SQL语句定义顺序 1 2 3 4 5 6 7 8 9 10 SELECT DISTINCT <select_list> FROM <left_table> <joi ...

  2. 如何在SQL Server查询语句(Select)中检索存储过程(Store Procedure)的结果集?

    如何在SQL Server查询语句(Select)中检索存储过程(Store Procedure)的结果集?(2006-12-14 09:25:36) 与这个问题具有相同性质的其他描述还包括:如何 ...

  3. python 3 mysql sql逻辑查询语句执行顺序

    python 3 mysql sql逻辑查询语句执行顺序 一 .SELECT语句关键字的定义顺序 SELECT DISTINCT <select_list> FROM <left_t ...

  4. mysql第四篇--SQL逻辑查询语句执行顺序

    mysql第四篇--SQL逻辑查询语句执行顺序 一.SQL语句定义顺序 SELECT DISTINCT <select_list> FROM <left_table> < ...

  5. SQL Server SQL高级查询语句小结(转)

    --select select * from student; --all 查询所有 select all sex from student; --distinct 过滤重复 select disti ...

  6. 45、SQL逻辑查询语句执行顺序

    一 SELECT语句关键字的定义顺序 SELECT DISTINCT <select_list> FROM <left_table> <join_type> JOI ...

  7. sql的查询语句的总结

    一:基本的查询sql 1:基本常用查询 select * from student; --select select all sex from student; --all 查询所有 select d ...

  8. NumberFormatException: Invalid int类型不匹配异常——使用SQL数据库查询语句select * from blacknumber order by _id desc limit ?,20;出现

    异常:类型不匹配 05-06 08:12:38.151: E/AndroidRuntime(14904): java.lang.NumberFormatException: Invalid int: ...

  9. 第四篇:记录相关操作 SQL逻辑查询语句执行顺序

    http://www.cnblogs.com/linhaifeng/articles/7372774.html 一 SELECT语句关键字的定义顺序 SELECT DISTINCT <selec ...

  10. SQL逻辑查询语句执行顺序

    阅读目录 一 SELECT语句关键字的定义顺序 二 SELECT语句关键字的执行顺序 三 准备表和数据 四 准备SQL逻辑查询测试语句 五 执行顺序分析 一 SELECT语句关键字的定义顺序 SELE ...

随机推荐

  1. [转帖]mysql.sock的作用

    mysql.sock的作用 链接:http://blog.itpub.net/28602568/viewspace-1797619/ 标题:mysql.sock的作用 作者:lōττéry©版权所有[ ...

  2. Struts学习(一)

    1.Struts开发基础 1.1  MVC的基本概念 mvc将一个应用系统的输入.处理和输出流程按照Model(模型).View(视图)和Controller(控制器)三部分进行分离,划分成模型层.视 ...

  3. CentOS8 下 Redis5.0.7 哨兵Sentinel 模式配置指南

    下载Redis Redis下载链接 解压缩 tar -xzvf redis-5.0.7.tar.gz 编译安装 make和gcc依赖 可通过yum -y install gcc automake au ...

  4. 极*Java速成教程 - (4)

    Java语言基础 多态 多态是面向对象的一大重要特性,如果说封装是隐藏一个类怎么做,继承是确定一系列的类做什么,那多态就是通过手段去分离做什么和怎么做. 向上转型与收窄 在开发者将一类事物封装成类以后 ...

  5. [Codeforces 1246B] Power Products (STL+分解质因数)

    [Codeforces 1246B] Power Products (STL+分解质因数) 题面 给出一个长度为\(n\)的序列\(a_i\)和常数k,求有多少个数对\((i,j)\)满足\(a_i ...

  6. mysql5.7单机多实例安装

    基于之前的mysql5.7单实例安装 修改/etc/my.cnf文件如下(这里配置4个实例,可自行修改数目) # # 多实例配置文件,可以mysqld_multi --example 查看例子 # [ ...

  7. 2、数据类型和运算符——Java数据类型

    一.强类型语言和弱类型语言: 1.1 强类型语言 强类型语言是一种强制类型定义的语言,一旦某一个变量被定义类型,如果不经过强制转换,则它永远就是该数据类型了,强类型语言包括Java..net .Pyt ...

  8. nodejs版实现properties后缀文件解析

    1.propertiesParser.js let readline = require('readline'); let fs = require('fs'); // properties文件路径 ...

  9. letsencrypt 免费SSL证书申请, 自动更新

    Let's Encrypt 泛域名 证书申请 及自动更新 关键字:SSL证书.HTTPS 初次申请 1. 下载certbot wget https://dl.eff.org/certbot-auto ...

  10. css隐藏滚动条 兼容谷歌、火狐、IE等各个浏览器

    项目中,页面效果需要展示一个页面的移动端效果,使用的是一个苹果手机样式背景图,咋也没用过苹果,咋也不敢形容. 如下图所示: 在谷歌浏览器如图一滚动条顺利隐藏,但是火狐就如图二了,有了滚动条丑的一批. ...