必杀技———SQL基础整理系列(一)
SQL(Structured Query Language)——结构化查询语言
SQL语言的组成部分
- 数据定义语言 (DDL:Data Definition Language)
负责数据结构定义与数据库对象定义的语言,由CREATE、ALTER、DROP三个语法所组成,操作的对象包括关系表、视图、索引等。
- 数据操纵语言(DML: Data Manipulation Language)
其语句包括动词SELECT(查询)、INSERT(添加)、UPDATE(修改)、DELETE(删除)表中的行。
- 数据控制语言(DCL: Data Control Language)
其中包含可对数据访问权进行控制的指令,由 GRANT 和 REVOKE 两个指令组成。
- 事务处理语言(TPL: Transaction Processing Language)
它的语句能确保被DML语句影响的表的所有行及时得以更新。包括BEGIN TRANSACTION, COMMIT 和 ROLLBACK。
SQL数据基本定义功能——定义模式
CREATE SCHEMA <模式名> AUTHORIZATION <用户名>
例子:定义一个学生-课程模式
Create schema "S-T" authorization Zhang
不指明模式名则隐含为 模式名为用户名
Create schema authorization Zhang
CREATE SCHEMA <模式名> AUTHORIZATION <用户名> [<表定义子句> | <视图定义子句> | <授权定义子句>]
例子:
Create schema test authorization Zhang
create table Tab1(A1 int,
A2 char(10),
A3 char(20))
SQL数据基本定义功能——删除模式
DROP SCHEMA <模式名> <CASCADE|RESTRICT>
例子:
Drop schema Zhang cascade
最最常用的在这里啦!!!
SQL数据基本定义功能——创建表
CREATE TABLE 表名
(<列名1> 数据类型 [列级约束],
[<列名2> 数据类型 [列级约束],]
……,
[表级约束])
例子:
- 创建表Students
关系模式 Students ( Sno, Sname, Ssex, Sage, Sdept )
Create table Students
(Sno char(11),
Sname char(20),
Ssex char(2),
Sage int,
Sdept char(20),
primary key(Sno))——————————————————这种是表级约束
Create table Students
(Sno char(11)primary key, ——————————————————————这是列级约束
Sname char(20),
Ssex char(2),
Sage int,
Sdept char(20))
- 创建表Courses
关系模式 Courses ( Cno, Cname, Cpno, Ccredit )
Create table Courses
(Cno char(4),
Cname char(40),
Cpno char(4),
Ccredit int,
primary key (Cno),——————————————————————————————这是表级约束
Foreign Key (Cpno) REFERENCES Courses(Cno))—————这是定义外键
- 创建表SC
关系模式 SC ( Sno, Cno, Grade )
Create table SC
( Sno char(9),
Cno char(4),
Grade int,
Primary key(Sno,Cno),
foreign key (Sno) references Students (Sno),
foreign key (Cno) references Courses (Cno))
SQL数据基本定义功能——数据类型
char(n) | 固定长度为n的字符串 |
varchar(n) | 可变长度为n的字符串 |
smallint | 短整数 |
int | 长整数 |
numberic(p,s) | 定点数。由p位数字组成,包括s位小数 |
float(n) | 精度至少为n位数字的浮点数 |
real | 取决于机器精度的浮点数 |
double precision | 取决于机器精度的双精度浮点数 |
date | 日期,格式为年、月、日,YYYY-MM-DD |
time | 时间,格式为时、分、秒,HH-MM-SS |
SQL数据基本定义功能——表的修改
添加列|完整性约束:
ALTER TABLE <表名> ADD <列名> <数据类型> [完整性约束]
删除列|完整性约束:
ALTER TABLE <表名> DROP <列名> <数据类型> [完整性约束]
修改列:
ALTER TABLE <表名> ALTER COLUMN <列名> <数据类型>
例子:
在学生表中添加字段Sclass,字符类型,长度20
Alter table Students add Sclass char(20)
将年龄的数字类型由字符型改为整型
Alter table Students alter coiumn Sage int
增加课程名称必须取唯一值的约束条件
Alter table Courses add unique (Cname)
SQL数据基本定义功能——表的删除
Drop table <表名> [restrict | cascade]
Restrict: (严格删除)表删除有限制条件,不能被其他表的约束所引用,不能有视图、触发器、存储过程或函数
Cascade: (级联删除)把一个基本表的定义连同表上的所有记录、索引以及由此基本表导出的所有视图都删除,并释放相应的存储空间
例子:
Drop table Students cascade
总是晚上才有时间码字,不积跬步,无以至千里,基础还是很重要的,下一篇开始介绍SQL查询语句,敬请关注!
必杀技———SQL基础整理系列(一)的更多相关文章
- 11、SQL基础整理(变量)
变量 定义变量:declare @hello varchar(20) 赋值:set @hello = ‘你好’ select(结果框显示)/print(消息框显示) @hello *三行必须同时 ...
- 8、SQL基础整理(约束)
约束 主键约束 防止在新增数据时出错,有约束性,起唯一标志的作用,在新增条目的时候防止不慎添加重复内容(不允许有null值) 1. 右键—设计—设置主键 2.在创建表格时设置 code int pr ...
- 5、SQL基础整理(字符串函数)
字符串函数 ASCII 返回字符串首字母的ascii编码 select ASCII('name') select ASCII(name) from xuesheng select *from xues ...
- SQL脚本整理系列 三
触发器 SQL 2008 怎么实现删除学生表里面的一条记录,成绩表里面关于这个学生的记录也同时删掉,谢求具体代码 --创建表 DROP TABLE tstudent GO CREATE TABLE t ...
- SQL脚本整理系列一 分隔函数
原来效果: fName Scroe 王某某 ,, 李某某 , 王某某 李某某 李某某 ,, 王某某 执行后效果: name score 李某某 李某某 李某某 王某某 王某某 王某某 王某某 王某某 ...
- 17、SQL基础整理(事务)
事务 事务==流程控制 确保流程只能成功或者失败,若出现错误会自动回到原点 例: begin tran insert into student values('111','王五','男','1999- ...
- 16、SQL基础整理(触发器.方便备份)
触发器(方便备份) 本质上还是一个存储过程,只不过不是通过exec来调用执行,而是通过增删改数据库的操作来执行(可以操作视图) 全部禁用触发器 alter table teacher disable ...
- 15、SQL基础整理(视图)
视图 即虚拟表 系统-右键-新建视图 编辑前200行 select *from studentscore 代码创建法: create view studentscore as select stude ...
- 14、SQL基础整理(存储过程)
存储过程procedure(proc) 数据库—可编程性—存储过程 新建存储过程: create proc firstproc as select *from fenshu go 执行存储过程: 存储 ...
随机推荐
- SQL Server 系列文章快速导航(SWF版)
一.前言 在博客园写博客不自不觉已经有5个年头了,一开始只是为了记录工作中遇到的问题和解决办法,后来写的文章不自不觉的侧重在SQL Server方面的技术文章,在2014年1月终于鼓起勇气申请了微软S ...
- 返回顶部的功能 div固定在页面位置不变
1.你在网上搜索的时候,可能会搜索到div固定在页面上,不随滚动条滚动而滚动是用CSS写的,写法是position:fixed;bottom:0; 但是这个在iframe满地跑的页面实际开发中,有啥用 ...
- IDDD 实现领域驱动设计-理解限界上下文
上一篇:<IDDD 实现领域驱动设计-理解领域和子域> <实现领域驱动设计>前两章内容,基本上读完了,和<领域驱动设计>不同的是,它把很多的概念都放在前面进行讲述了 ...
- 一个前端所需具备的PS能力
前端网页设计+静态实现案例 放一个2天半内给某公司完成的(设计 + 静态实现)的案例吧,静态阴影用CSS3实现的http://www.cnblogs.com/MuYunyun/p/5693615.ht ...
- UWP简单示例(二):快速开始你的3D编程
准备 IDE:Visual Studio 2015 了解并学习:SharpDx官方GitHub 推荐Demo:SharpDX_D3D12HelloWorld 第一节 世界 世界坐标系是一个特殊的坐标系 ...
- iOS 编辑UITableView(根据iOS编程编写)
上个项目我们完成了 JXHomepwner 简单的应用展示,项目地址.本节我们需要在上节项目基础上,增加一些响应用户操作.包括添加,删除和移动表格. 编辑模式 UITableView 有一个名为 e ...
- Effective前端3:用CSS画一个三角形
p { text-indent: 2em } .triangle-container p { text-indent: 0 } img { margin: 15px 0 } 三角形的场景很常见,打开一 ...
- 超越 JSON: Spearal 序列化协议简介
Spearal 是一个新的开源的序列化协议,这个协议旨在初步替换JSON 将HTML和移动应用连接到Java的后端. Spearal的主要目的是提供一个序列协议,这个协议即使是在端点间传输的复杂的 ...
- FastSocket学习笔记~再说客户端与服务端的组成
废话多说 很久之前,我写过几篇FastSocket的文章,基本属于使用的方法,而缺乏对概念的总结讲解,而本讲就是弥补一下上几讲的不足,将核心的模块再说说,再谈谈,再聊聊! 首先FastSocket由C ...
- Spring下ActiveMQ实战
MessageQueue是分布式的系统里经常要用到的组件,一般来说,当需要把消息跨网段.跨集群的分发出去,就可以用这个.一些典型的示例就是: 1.集群A中的消息需要发送给多个机器共享: 2.集群A中消 ...