SQL概述和定义

1.sql的基本组成

数据定义:ddl

数据操纵:dml

嵌入式sql和动态sql:高级语言

完整性:ddl定义的设置设置数据必须满足的完整性约束条件的命令

权限:ddl 关系和视图的权限

几个动词:

  • 数据查询:select
  • 数据定义:create drop alter
  • 数据操纵:insert update delete
  • 数据控制:grant revoke

2.基本类型

char

varchar

int

smallint

numeric 纽迈瑞克 英[njuː'merɪk] p整数位 n小数位

double

float

boolean

date

time

3.表的创建修改和删除

1.创建

create table 表名(

列名 数据类型 【列级完整性约束】

列名 数据类型 【列级完整性约束】

....

表级完整性约束

)

实体完整性:

  • 一个的可以直接在列后面加上PRIMARY KEY

    表级完整性约束一般就是PRIMARY KEY(属性1,属性2) 一个或者多个都可以

参照完整性:

列后面加上reference 表名 属性名

最后面加上:foreign key reference 表名(属性名) on delete cascade | set null

on delete cascade:表示删除被参照的元组的时候 同时删除参照关系中的元组

on delete set null:表示删除被参照关系的元组时,将参照关系的相应属性设置为空值

属性上加约束

primary key

reference 表名 属性名

not null

unique

not null unique:不为空且唯一

check 限制取值

check (sex = 男 or sex = 女)

check(余额 >= 0)

check(年龄 >= 18 and 年龄 <= 60)

全局约束

  • 基于元组的检查子句

create table e (

eno char(10) primary key,

入职日期 date,

离职日期 date,

check(入职日期 <= 离职日期)

);

基于断言的语法格式

create assertion 断言名 check 条件

create assertion asse_sc check

(

not exists (

select * from sc where Cno in (

select Cno from c where teacher = '张勇' )

and Sno in (select Sno from Students where sex ='M')

)

)

修改表

alter table 表名 add column 列名 数据类型 列级完整性约束;

alter table 表名 drop 完整性约束

alter table 表名 modify 列名 数据类型

alter table s modify status int;修改数据类型为int

添加check约束起名为c_cno

alter table s add constraint c_cno check()

drop table 表名

3.索引的创建和删除

  1. 唯一索引:保证数据的唯一性
  2. 加快检索速度
  3. 加速表与表之间的连接
  4. 在使用order by和group by子句中进行检索数据时,可以显著减少查询分组和排序的时间
  5. 使用优化隐藏器提高系统的性能
  6. 索引可以分为聚集索引和非聚集的

索引创建

create unique/cluster index 索引名字 on 表名 列名 次序,列名 次序

次序:ase desc

unique:此索引的每一个索引值只对应唯一的记录

cluster:表名要建立的索引是聚簇索引 意思为索引项的顺序是与表中记录的物理顺序一致的索引组织

create unique index sss on S(sno) 在S表的Sno列上加上索引默认是升序

create unique index ppp on P(pno) desc

create unique index aaa on SPJ(sno asc, pno desc) ;spj表加上索引 属性sno升序 pno降序

drop index 索引名

视图的创建

create view 视图名字(列名)

as select 子查询

with check option:表示update insert delete操作时数据能及时更新

create view student_v as

select sno,sname,sage,sex

from student

where sd = 'cs'

with check option;

drop view 名称;

相关推荐
一只fish1 分钟前
MySQL 8.0 OCP 1Z0-908 题目解析(16)
数据库·mysql
泊浮目30 分钟前
未来数据库硬件-网络篇
数据库·架构·云计算
静若繁花_jingjing44 分钟前
Redis线程模型
java·数据库·redis
飞翔的佩奇2 小时前
Java项目:基于SSM框架实现的忘忧小区物业管理系统【ssm+B/S架构+源码+数据库+毕业论文+开题报告】
java·数据库·mysql·vue·毕业设计·ssm框架·小区物业管理系统
亚马逊云开发者2 小时前
全景解读亚马逊云科技的 GenBI 解决方案:三大路径助力企业智能决策升级
sql·llm
ZWZhangYu8 小时前
LangChain 构建向量数据库和检索器
数据库·langchain·easyui
feifeigo1239 小时前
升级到MySQL 8.4,MySQL启动报错:io_setup() failed with EAGAIN
数据库·mysql·adb
火龙谷11 小时前
【nosql】有哪些非关系型数据库?
数据库·nosql
焱焱枫12 小时前
Oracle获取执行计划之10046 技术详解
数据库·oracle
双力臂40412 小时前
MyBatis动态SQL进阶:复杂查询与性能优化实战
java·sql·性能优化·mybatis