数据库-SQL查询语言(一)
SQL数据定义
DDL
sql的DDL不仅能定义一组关系,还能定义每个关系的信息,包括:
- 每个关系的模式
- 每个属性的取值类型
- 完整性约束
- 每个关系的维护的索引集合
- 每个关系的安全性和权限信息
- 每个关系在磁盘上的物理存储结构
基本类型
sql支持的常用类型:
- char(n): 固定长度的字符串,n为其长度并可被设置,字符串长度不够n时,自动添加空格;
- varchar(n):可变长度字符串,最长为n;
- int:整型
- smallint:小整型
- numeric(p,d):定点数,该数共p位,有d位在小数点右边。eg, numeric(3,1)可以储存44.5,不可以储存0.32,333.3;
- real,double,precision:浮点数与双精度浮点数
- float(n):精度至少为n位的浮点数
基本模式定义
create table定义关系
create table student
(s_id varchar(8),
s_name varchar(20),
dept_ment varchar(20),
class varchar(10),
dormitory varchar(20),
primary key (s_id),
foreign key (dept_name) references department);
定义了student关系,包含学生ID,姓名,院系,班级,寝室。在该关系中,s_id为主键,用 primary key (s_id) 指出;
dept_name是外键,用 foreign ket (dept_name) references department 指出,并且 dept_name 是 department 的主键;
- primary key (A,B,C,···):A,B,C···是构成关系的主键,主键属性必须非空且唯一,通常选用一个属性为主键
- foreign key (A,B,C··) references other_table:表明关系中A,B,C···属性上的取值必须对应other_table关系某元组在主键上
- 的取值,不允许出现other_table中未出现的值;
- not null:表示在该属性上不允许出现空值
insert into插入元组
insert into student
values(20229991,'Wang Yang','CS','CS-01','B4-202');
也可以多行插入
insert into student values(20229992,'Ming Wang','Math','Math-02','P2-301'),
(20229993,'Zhang Shui','CS','CS-02','B4-411'),
(20229993,'Liu Ping','CS','CS-03','B4-518');
在这里说明一下,只有且必须在语句结束时打分号
如果不记得顺序,也可以这样插入
insert into student(s_name,s_id,dept_name,dormitory,class)
values('Li Mei',20229913,'Finance','G2-117','Fi-09');
在查询的基础上插入元组。比如说,让每个高考成绩在700以上的学生成为优异生奖学金获得者,且标注奖学金6000
insert into prise
select s_id,s_name,dept_name,6000
from studnet
where CET_grade=6000;
delete 删除元组
delete from student;
删除关系student中所有元组,但student模式还存在;
drop 删除元组
drop table student;
删除student所有元组,删除student的模式,除非create table 重建student,否则不能向其中插入元组;
条件删除
delete from r where P;
从关系r中删除满足条件P的元组
/*从关系student中删除s_name为Wang gang的元组*/
delete from student
where s_name='Wang gang';
/*从关系student中删除s_id在20229950到20229999中间的学生元组*/
delete from student
where s_id between 20229950 and 20229999; /*从关系student中删除一些学生元组,他们的系在一教办公*/
delete from student
where dept_name in (select dept_name
from department
where building = 'DS1___%'); /*删除高考成绩低于全体学生平均分的学生元组*/
delete from student
where CET_grade < (select arg(CET_grade)
from student);
通常delete可以配合查询语句删除特定元组,比较自由
alter table 为已有关系增加(减少)属性
alter table student add grade D;
向关系student中增加属性grade,其域为D;
alter table student drop grade;
从关系student中去掉属性grade,不过这条命令在很多数据库系统中不被支持;
数据库-SQL查询语言(一)的更多相关文章
- 数据库先系统与原理第三章笔记:数据库SQL查询语言
SQL概述 SQL发展 SQL特点 SQL查询基本概念 单表查询 投影查询 1.查询指定列: SELECT 列名1,列名2,列名3,.....FROM Table_Name; #查询全部列:SELEC ...
- 数据库—SQL语句
下列语句部分是Mssql语句,不可以在access中使用. SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT,DEL ...
- Oracle 数据库SQL性能查看
作为一个开发/测试人员,或多或少都得和数据库打交道,而对数据库的操作归根到底都是SQL语句,所有操作到最后都是操作数据,那么对sql性能的掌控又成了我们工作中一件非常重要的工作.下面简单介绍下一些查看 ...
- 你用什么方法检查 PHP 脚本的执行效率(通常是脚本执行时间)和数据库 SQL 的效率(通常是数据库 Query 时间), 并定位和分析脚本执行和数据库查询的瓶颈所在?
php: 一般是在你要检查的代码开头记录一个时间,结尾记录一个时间.取差值, 数据库SQL的效率 sql的explain(mysql),启用slow query log记录慢查询. 通常还要 ...
- 数据库SQL Server与C#中数据类型的对应关系
ylbtech- .NET-Basic:数据库SQL Server与C#中数据类型的对应关系 数据库SQL SServer与C#中数据类型的对应关系 1.A,返回顶部 数据库 C#程序 int int ...
- 我的mysql数据库sql优化原则
原文 我的mysql数据库sql优化原则 一.前提 这里的原则 只是针对mysql数据库,其他的数据库 某些是殊途同归,某些还是存在差异.我总结的也是mysql普遍的规则,对于某些特殊情况得特殊对待. ...
- 学生选课数据库SQL语句45道练习题整理及mysql常用函数(20161019)
学生选课数据库SQL语句45道练习题: 一. 设有一数据库,包括四个表:学生表(Student).课程表(Course).成绩表(Score)以及教师信息表(Teacher).四 ...
- 数据库sql优化方案
声明:这个不是我自己写的,是我们老师给我,我拿出来分享一下! 为什么要优化: 随着实际项目的启动,数据库经过一段时间的运行,最初的数据库设置,会与实际数据库运行性能会有一些差异,这时我们 ...
- 数据库 SQL Server2012安装步骤详解
这篇文章主要给大家讲解一下数据库SQL Server2012的安装步骤(若有雷同纯属巧合,还望谅解!) 在正式安装之前,我们需要进行两个设置: ① 首先需要关闭Windows防火墙,若不关闭,后续的安 ...
随机推荐
- WeChair项目Beta冲刺(8/10)
团队项目进行情况 1.昨日进展 Beta冲刺第八天 昨日进展: 前后端并行开发,项目按照计划有条不絮进行 2.今日安排 前端:扫码占座功能和预约功能并行开发 后端:扫码占座后端逻辑开发,编码使用 ...
- 团队Github实践训练
这个作业属于哪个课程 软件工程 (福州大学至诚学院 - 计算机工程系) 团队名称 WeChair 这个作业要求在哪里 团队Github实践训练 这个作业的目标 通过github实现团队协作编码 作业正 ...
- awk 命令使用入门
Linux 下处理和分析文本文件内容,AWK 命令是一个强有力的工具.特别是文件内容是以行和列的形式排版的时候,AWK 就是命令行界的 Excel 啊! 简单的 awk 命令可以直接在命令行中使用,复 ...
- spring 整合redis集群中使用@autowire无效问题的解决办法
1.视频参考黑马32期宜立方商城第6课 redis对于的代码 我们先变向一个redis客户端的接口文件 package com.test; public interface JedisClient { ...
- 10、一个action中处理多个方法的调用第一种方法动态调用
我们新建一个用户的action package com.weiyuan.test; import com.opensymphony.xwork2.ActionSupport; /** * * 这里不用 ...
- 服务扫描-dmitry、nmap、amap和服务识别
dmitry使用-pb参数可以进行常用端口的banner抓取. 抓取效果: 强大的nmap也可以进行banner抓取,但是需要使用nmap内置的banner.nse脚本: kali中还有一个工具叫am ...
- C# 人脸识别库
.NET 人脸识别库 ViewFaceCore 这是基于 SeetaFace6 人脸识别开发的 .NET 平台下的人脸识别库这是一个使用超简单的人脸识别库这是一个基于 .NET Standard 2. ...
- 01-最大子列和问题(java)
问题描述:给定N个整数的序列{A1,A2,A3,…,An},求解子列和中最大的值. 这里我们给出{-2,11,-4,13,-5,-2}这样一个序列,正确的最大子列和为20 该题是在数据结构与算法中经常 ...
- 服务消费者(Feign-上)
上一篇文章,讲述了Ribbon去做负载请求的服务消费者,本章讲述声明性REST客户端:Feign的简单使用方式 - Feign简介 Feign是一个声明式的Web服务客户端.这使得Web服务客户端的写 ...
- Linux文件权限学习笔记
文件权限共10个字符,第一个字符表示该文件是[文件夹]或[文件]——如果是字符“d"则表示该文件是文件夹:如果是字符“-”则表示是文件. 后九个字符,三个一组,共三组,分别表示[所有者权限] ...