返回顶部
首页 > 资讯 > 数据库 >SQL基础随记 (Tobe Continued) - G
  • 582
分享到

SQL基础随记 (Tobe Continued) - G

SQL基础随记(TobeContinued)-G 2021-02-05 03:02:11 582人浏览 猪猪侠
摘要

sql基础随记 (Tobe Continued)   其实这里的随记,要是好久不接触突然被问的话有时还真的一时答不上,自己写一遍胜过盲扫。当然,也有些常读常新的地方会记录下来。   对SQL语言进行划分 DDL --- Data

SQL基础随记 (Tobe Continued) - G

sql基础随记 (Tobe Continued)

 

其实这里的随记,要是好久不接触突然被问的话有时还真的一时答不上,自己写一遍胜过盲扫。当然,也有些常读常新的地方会记录下来。

 

对SQL语言进行划分

DDL --- Data Definition Language --- 定义 --- 增删改数据库和表的结构

DML --- Data Manipulation Language --- 操作 --- 对记录增删改

DQL --- Data Quary Language --- 查询 --- 对记录进行查询

DCL --- Data Control Language --- 控制 --- 访问权限和安全规则

要是要突然问的话有时还真的一时回答不上,记住单词胜过记缩写

 

DBMS的分类

 

  • 列存储数据库说是“可以降低系统的I/O,但功能相对有限”,不过我看到了一段有意思的话觉得很有道理

    列存储常见于分布式文件系统,如HBase

  • 图(这种数据结构)存储了实体(对象)之间的关系。以最典型的人与人社交关系为例,其数据模型主要是以节点和边来实现。特点在于可以有效解决复杂的关系问题。

 

DDL

  • 创建表时可以在create table tableName (...)后面追加参数,可以追加的有

    • engine = InnoDB

    • CHARACTER SET = utf8 COLLATE = utf8_general_ci
      

      其中CHARACTER SET是指定字符编码,COLLATE是指定排序规则。且utf8_general_ci是对大小写不敏感,对大小写敏感是utf8_bin

      在定义varchar()类型字段的时候也可以后缀CHARACTER SET = xxx COLLATE = yyy

       

  • 在创建索引的时候我们可以选择不同类型的索引(UNIQUE INDEX --- 唯一索引 或 NORMAL INDEX --- 普通索引)以及不同的索引方式(BTREE 或 HASH),如

    CREATE TABLE XXX(
    ...
    UNNIQUE INDEX indexName (字段名) USING BTREE
    ...
    )
    

    索引分为单列索引和组合索引,组合即一个索引可以包含多个列

     

  • 约束

    • 主键,可以是一个字段也可以是多个字段
    • 外键
    • UNIQUE (唯一性)约束,
    • NOT NULL 约束
    • DEFAULT 约束,在插入记录时如果该字段为空,那么就会设置为默认值。(而不是“不变量”的意思,它仍然可变)
    • CHECK 约束 (mysql8.0.16后版本支持)

     

  • 理论上设计数据表的“三少一多”原则

    • 表个数少

    • 表中字段少

    • 联合主键字段少

    • 主键和外键多

      表的设计核心就是简单可复用,主键是一张表的代表,因此主键外键越多,说明表之间的利用率最高。
       

      但这个原则不是绝对的,因为有时我们需要牺牲数据的冗余度来换取处理数据的效率,毕竟join总是会造成复杂。

      另外在大型项目中,大量的更新以及高并发的情况下,外键会造成额外的开销,也容易造成死。因此在业务量较大时,可以采用在业务层实现,取消外键来提高效率。因此在实际生产中为了方便维护基本不使用外键

      另外也不推荐使用自增长主键,不利于维护。例如银行一般使用唯一表示字段uuid+日期+渠道流水(unique index)来保证数据唯一性。

       

    • 修改字段类型不要忘记COLUMN

      ALTER TABLE tableName MODIFY COLUMN newName type;
      

      修改字段名

      ALTER TABLE tableName CHANGE oldName newName type;
      

      修改大表字段需要谨慎 容易引发表结构写锁。(0623)

       

您可能感兴趣的文档:

--结束END--

本文标题: SQL基础随记 (Tobe Continued) - G

本文链接: https://lsjlt.com/news/6820.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • SQL基础随记 (Tobe Continued) - G
    SQL基础随记 (Tobe Continued)   其实这里的随记,要是好久不接触突然被问的话有时还真的一时答不上,自己写一遍胜过盲扫。当然,也有些常读常新的地方会记录下来。   对SQL语言进行划分 DDL --- Data ...
    99+
    2021-02-05
    SQL基础随记 (Tobe Continued) - G
  • SQL基础随记3 范式 键 - G
    SQL基础随记3 范式 键 什么是范式?哈,自己设计会使用但是一问还真说不上来。遂将不太明晰的概念整体下   什么是 & 分类 范式(NF),一种规范,设计数据库模型时对关系内部各个属性之间的联系的合理化程度的不同等级的规范要求...
    99+
    2014-11-13
    SQL基础随记3 范式 - G
  • SQL基础随记2 视图 存储过程 - G
    SQL基础随记2 视图 存储过程   View CREATE/ALTER/DROP VIEW ViewName as SELECT(...) 可以在视图的基础上继续创建视图,即,将之前创建的视图当做表名放在新视图...
    99+
    2020-04-02
    SQL基础随记2 视图 存储过程 - G
  • Oracle 笔记(七)、PL/SQL 基础
    一、概述、PL/SQL 块结构PL/SQL 是Oracle产品对 SQL 语言的扩展。PL/SQL 块共分为三个部分:声明部分、可执行部分、异常部分。DECLARE    .....
    99+
    2024-04-02
  • sql初学者笔记 语法基础
    常见注释 -- 很少支持 行内注释 段落注释 基础语法 SELECT 检索数据 语法 作用 例子 释义 select 查找列,并返回行 select prod_name from products;#可使...
    99+
    2018-10-06
    sql初学者笔记 语法基础
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作