SQL的特点:

  • 综合统一
  • 高度非过程化(存取路径的选择以及SQL的操作过程由系统自动完成)
  • 面向集合的操作方式,以同一种语法结构提供多种使用方法(可以在终端键盘上直接键入SQL命令对数据库进行操作,也能够嵌入到高级语言(C,C++,JAVA)程序中)

模式,外模式,和内模式:

关系模型支持三级模式结构:模式,外模式,和内模式;

模式:是指数据库中全体数据的逻辑结构和特征的描述,是所有用户的公共数据视图。它涉及的仅仅是对于某一类数据的结构和属性的描述。模式的一个具体值称为模式的一个实例,同一模式下可以有很多个实例。模式是相对稳定的,而实例是相对变动的。

外模式:也称子模式,或用户模式,是数据库用户能够看见和使用的局部数据的逻辑结构和特征的表述,是数据库用户的数据视图。是与某一应用有关的数据的逻辑表示。

内模式:也称存储模式,一个数据库只有一个内模式。他是数据物理结构和存储方式的描述,是数据库内部的组织方式。

模式与外模式的关系:一对多。

外模式与应用的关系:一对多。

其中外模式包括若干视图和部分基本表,数据库模式包括若干基本表,内模式包括若干存储文件。

数据库,模式,表的关系:

一个数据库可以建立多个模式,一个模式下通常包括多个表,视图和索引等数据库对象;

SQL数据库定义语句:

  1. 模式 :创建:create schema 删除:drop schema
  2. 表: 创建:create table 删除:drop table
  3. 视图:创建:create view 删除:drop view
  4. 索引:创建:create index 删除:drop index

模式的定义与删除:

1.定义模式:

Create schema 模式名 authorization 用户名

定义模式实际上定义了一个命名空间,建立了一个数据库的命名空间,一个框架。在创建模式时,同时也可以创建基本表,以及视图,并且可以定义授权。

2.删除模式:

drop schema 模式名 cascade或者drop schema 模式名 restrict

cascade:为级联,表示删除该模式时,删除该模式中所有的数据库对象。

Restrict:为限制,表示如果该模式中已经定义了下属的数据库对象,则拒绝执行该语句。

基本表:

1.定义基本表:

Create table 表名 (列名 数据类型 列级完整性约束条件,

列名 数据类型 列级完整性约束条件,

表级完整性约束条件);

如果完整性约束涉及该表的多个属性列,则必须定义在表级上,否则既可以定义在表级也可以定义在列级。

例如:

Create table course(
Cno char(4) primary key,/* primary key标示主码*/
Cname char(40) not NULL,/* 列级完整性约束条件,Cname 不能为空*/
Cpno char(4)Ccredit smallint,
foreign key(Cpno)refernces course(Cno)
/* 表级完整性约束条件,Cpno是外码,被参照表是:Cno;*/
);

定义表的模式:

方法一:在表中明显的定义模式名:

Create table “S-T”.course(…);/*course所属的模式是S-T*/

方法二:在创建模式的同时创建表;

方法三:设置所属的模式。

当创建基本表时,若没有指定模式,系统会根据搜索路径来确定该对象所属的模式(搜索结果中第一个存在的模式)。

显示当前的搜索路径:

Show search_path; /*默认值是$user,public ,首先搜索与用户名相同的模式名,不过不存在这使用public*/

设置搜索路径,如:

Set search_path to “S-T”,public;

然后创建基本表:

Create table course(…);

2.修改基本表:

Alter table 表名

Add [column] 新列名 数据类型 完整性约束 /*增加新列*/

Add 表级完整性约束 /*增加表级完整性约束*/

Drop [column] 列名 cascade /**强制删除*/

Drop [column] 列名 restrict

Alter column 列名 数据类型 /*修改原有列定义**/

3.删除基本表:

Drop table 表名 restrict //有限制条件的删除,不能被其他的对象引用。

或者Drop table 表名cascade //强制删除

关系数据库—SQL学习笔记的更多相关文章

  1. ORALCE PL/SQL学习笔记

    ORALCE  PL/SQL学习笔记 详情见自己电脑的备份数据资料

  2. Oracle之PL/SQL学习笔记

    自己在学习Oracle是做的笔记及实验代码记录,内容挺全的,也挺详细,发篇博文分享给需要的朋友,共有1w多字的学习笔记吧.是以前做的,一直在压箱底,今天拿出来整理了一下,给大家分享,有不足之处还望大家 ...

  3. SQL学习笔记

    SQL(Structured Query Language)学习笔记 [TOC] Terminal登录数据库 1.登录mysql -u root -p ; 2.显示所有数据库show database ...

  4. [SQL学习笔记][用exists代替全称量词 ]

    学习sql的必经问题. 学生表student (id学号 Sname姓名 Sdept所在系) 课程表Course (crscode课程号 name课程名) 学生选课表transcript (studi ...

  5. SQL学习笔记——SQL初入门,Ubuntu下MySQL的安装

          刚开始接触sql,于是准备在Ubuntu下学习sql,就跟着itercast的sql教程开始入门了. 下面只是我个人的记录,高手请绕道: 一. 在安装之前,我们可以用下面这个命令通过开放端 ...

  6. pl/sql学习笔记---马士兵教程38-48

    Procedure Language/Structure query Language 一.关于语言学习 1.数据类型 2.语法   通过例子来学习很快就能明白 set serverputout on ...

  7. SQL学习笔记之SQL查询练习题1

    (网络搜集) 0x00 表名和字段 –1.学生表 Student(s_id,s_name,s_birth,s_sex) –学生编号,学生姓名, 出生年月,学生性别 –2.课程表 Course(c_id ...

  8. SQL学习笔记三(补充-1)之MySQL存储引擎

    阅读目录 一 什么是存储引擎 二 mysql支持的存储引擎 三 使用存储引擎 一 什么是存储引擎 mysql中建立的库===>文件夹 库中建立的表===>文件 现实生活中我们用来存储数据的 ...

  9. SQL学习笔记一之初识数据库

    阅读目录 一 数据库管理软件的由来 二 数据库概述 三 mysql介绍 四 下载安装 五 mysql软件基本管理 六 初识sql语句 一 数据库管理软件的由来 基于我们之前所学,数据要想永久保存,都是 ...

随机推荐

  1. 【夯实PHP基础】PHP的反射机制

    本文地址 分享提纲: 1. 介绍 2. 具体例子 2.1 创建Persion类 2.2 反射过程 2.3 反射后使用 1. 介绍 -- PHP5添加了一项新的功能:Reflection.这个功能使得p ...

  2. ASP.NET MVC搭建项目后台UI框架—11、自动加载下拉框查询

    ASP.NET MVC搭建项目后台UI框架—1.后台主框架 需求:在查询记录的时候,输入第一个字,就自动把以这个字开头的相关记录查找出来,输入2个字就过滤以这两个子开头的记录,依次类推. 突然要用到这 ...

  3. activiti工作流的web流程设计器整合视频教程 SSM和独立部署

    本视频为activiti工作流的web流程设计器整合视频教程 整合Acitiviti在线流程设计器(Activiti-Modeler 5.21.0 官方流程设计器) 本视频共讲了两种整合方式 1. 流 ...

  4. 应用.Net+Consul维护RabbitMq的高可用性

    懒人学习的过程就是工作中老大让干啥让做啥就研究研究啥,国庆放假回来的周末老大通过钉钉给我布置了个任务, RabbitMQ高可用解决方案,我想说钉钉太坑了: 这是国庆过后9号周日晚上下班给的任务,我周一 ...

  5. JavaScript--面向对象--猜拳游戏

    //html代码 <!doctype html> <html> <head> <meta charset="UTF-8"> < ...

  6. Regular Express正则表达式基础

    一. 创建一个正则表达式RegExp,有两种方式如下图所示 二. 创建一个正则表达式RegExp详述说明 1.构造函数 //RegExp 是js中一个内置的对象,是正则表达式的缩写 var reg = ...

  7. 最新GHOST XP系统下载旗舰增强版 V2016年

    系统来自:系统妈:http://www.xitongma.com 深度技术GHOST xp系统旗舰增强版 V2016年3月 系统概述 深度技术ghost xp系统旗舰增强版集合微软JAVA虚拟机IE插 ...

  8. 如何用Github版本控制非Github库

    Git的图形化客户端有很多,不同的人可能习惯用不同的客户端.本人更习惯于Github的客户端,因为上Github比较多,同步代码到Github用官方的客户端是最方便的,所以也就更习惯于使用Github ...

  9. 让OData和NHibernate结合进行动态查询

    OData是一个非常灵活的RESTful API,如果要做出强大的查询API,那么OData就强烈推荐了.http://www.odata.org/ OData的特点就是可以根据传入参数动态生成Ent ...

  10. Java多线程中的死锁问题

    Java程序基本都要涉及到多线程,而在多线程环境中不可避免的要遇到线程死锁的问题.Java不像数据库那么能够检测到死锁,然后进行处理,Java中的死锁问题,只能通过程序员自己写代码时避免引入死锁的可能 ...