数据库-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,不过这条命令在很多数据库系统中不被支持;

原文地址:https://www.cnblogs.com/qinghemo/p/11728781.html

时间: 2024-10-17 19:06:16

数据库-SQL查询语言(一)的相关文章

数据库—SQL语句

下列语句部分是Mssql语句,不可以在access中使用. SQL分类:   DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE)   DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT)   DCL—数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK) 首先,简要介绍基础语句: 1.说明:创建数据库 CREATE DATABASE database-name   2.说明:删除数据库 drop database dbname

你用什么方法检查PHP脚本的执行效率(通常是脚本执行时间)和数据库SQL的效率(通常是数据库Query时间),并定位和分析脚本执行和数据库查询的瓶颈所在?

腾讯 PHP脚本的执行效率 1, 代码脚本里计时. 2, xdebug统计函数执行次数和具体时间进行分析.,最好使用工具winCacheGrind分析 3, 在线系统用strace跟踪相关进程的具体系统调用. 数据库SQL的效率 sql的explain(mysql),启用slow query log记录慢查询. 通常还要看数据库设计是否合理,需求是否合理等.

数据库SQL优化大总结之 百万级数据库优化方

http://tw.streetvoice.com/anssm001/songs/album/93124674/ http://tw.streetvoice.com/anssm001/songs/album/93124684/ http://tw.streetvoice.com/anssm001/songs/album/93124698/ http://tw.streetvoice.com/anssm001/songs/album/93124716/ http://tw.streetvoice.

图解MYSQL JOIN ON,SQL JOIN 详解,数据库sql join语句

对于SQL的Join,在学习起来可能是比较乱的.我们知道,SQL的Join语法有很多inner的,有outer的,有left的,有时候,对于Select出来的结果集是什么样子有点不是很清楚.Coding Horror上有一篇文章(实在不清楚为什么Coding Horror也被墙)通过 文氏图 Venn diagrams 解释了SQL的Join.我觉得清楚易懂,转过来. 假设我们有两张表. Table A 是左边的表. Table B 是右边的表. 其各有四条记录,其中有两条记录是相同的,如下所示

数据库SQL审计、SQL优化、异常问题诊断、性能优化

数据库管理系统(简称 DBMS)无疑是任何数据密集型应用程序当中最为重要的组成部分,其肩负着处理大量数据以及高复杂性工作负载的重任.然而,数据库管理系统本身却往往难于管理,因为其中通常包含数百种配置"旋钮",用于控制诸如缓存内存分配量以及存储介质数据写入频率等要素.各类企业一般需要聘请专业人士以协助相关调配工作,但对于大多数企业而言,此类专业人才的开价亦相当高昂.而实际上,DBA所面临的挑战还远不止这些. 而今天一则名为"OtterTune"的机器学习DBMS系统刷

你用什么方法检查 PHP 脚本的执行效率(通常是脚本执行时间)和数据库 SQL 的效率(通常是数据库 Query 时间), 并定位和分析脚本执行和数据库查询的瓶颈所在?

1.PHP执行时间: $begin=microtime(true); //获取程序开始执行的时间 // some code here 待执行的代码 $stop=microtime(true); //获取程序执行结束的时间 list($m0,$s0)=explode(" ",$begin); list($m1,$s1)=explode(" ",$stop); $runtime=($s1+$m1-$s0-$m0)*1000; echo '<br />当前脚本

[转] oracle 数据库 SQL plus 连接方法

http://hi.baidu.com/zzy382/item/a5b197f97a38e01ba7298832 之前电脑上安装了一个 Oracle  有一段时间没用,就把密码给忘了,按上面链接里的操作,重置密码成功,步骤如下: connect system/oracle以 system 用户 oracle 密码连接 在进入 sql plus 界面后输入 / as oraclesys 回车即以管理用户登录.然后读取 dba_users 表内容可以 alter user system identi

SQL监控:mysql及mssql数据库SQL执行过程监控审计

最近生活有很大的一个变动,所以博客也搁置了很长一段时间没写,好像写博客已经成了习惯,搁置一段时间就有那么点危机感,心里总觉得不自在.所以从今天起还是要继续拾起墨笔(键盘),继续好好维护这个博客,写出心里最真实的想法,写出平时接触到的一些人和事以及一些新的技术.当然写博客也不是单纯的为了记录,也想通过博客来结交更多的朋友,今天在公司图书馆看到一句话大致说的是“在今天这个年代,已经很难等到三顾茅庐,诸葛亮也需要博客.微博和影响力”,在一年前就曾想过写一篇关于怎样通过博客来提高个人影响力的文章,我会尽

Oracle 数据库SQL性能查看

作为一个开发/测试人员,或多或少都得和数据库打交道,而对数据库的操作归根到底都是SQL语句,所有操作到最后都是操作数据,那么对sql性能的掌控又成了我们工作中一件非常重要的工作.下面简单介绍下一些查看oracle性能的一些实用方法: 1.查询每台机器的连接数 select t.MACHINE,count(*) from v$session t group by t.MACHINE 这里所说的每台机器是指每个连接oracle数据库的服务器,每个服务器都有配置连接数据库的连接数,以websphere