SQL速查文档

首先写这个文档记录一下我的学习记录

SQL(Structured Query Language)是一种数据库的结构化查询语言,常用的关系型数据库由 MySQL,SQL Server,Oracle,Access 等。那么什么是数据库呢,简而言之就是存储数据的仓库,Excel 为什么不算数据库呢,因为它能够存储的数据量真的太小了,Excel2016 到底是 1048576 行,意思是它最多存储 104 万条数据,但你要真存 104 万条数据在 Excel 里估计电脑不卡也残废。现在大数据时代数据动辄百万/千万,所以需要数据库来帮忙。总结一下,SQL 就是对存储在数据库中的数据进行查询等操作的一种语言,所以你知道了,SQL 本身是一种语言,如果你有语言学习的基础,那么学起 SQL 来就简单多了。

一、增

1.1创建数据表

CREATE TABLE
[IF NOT EXISTS] tb_name -- 不存在才创建,存在就跳过
(column_name1 data_type1 -- 列名和类型必选
  [ PRIMARY KEY -- 可选的约束,主键
   | FOREIGN KEY -- 外键,引用其他表的键值
   | AUTO_INCREMENT -- 自增ID
   | COMMENT comment -- 列注释(评论)
   | DEFAULT default_value -- 默认值
   | UNIQUE -- 唯一性约束,不允许两条记录该列值相同
   | NOT NULL -- 该列非空
  ], ...
) [CHARACTER SET charset] -- 字符集编码
[COLLATE collate_value] -- 列排序和比较时的规则(是否区分大小写等)

例子:
create table if not exists user_info_vip(
    id int primary key auto_increment comment '自增ID',
    uid int unique not null comment '用户ID',
    nick_name varchar(64) comment '昵称',
    achievement int default 0 comment '成就值',
     `level` int COMMENT '用户等级',
    job varchar(32) COMMENT '职业方向',         
    register_time datetime DEFAULT CURRENT_TIMESTAMP COMMENT '注册时间'
)character set utf8 collate utf8_general_ci;

1.2插入

1.2.1插入列

alter table 表名 add column 列字段名 数据类型

1.2.2插入行

insert into 表名 values (列 1 值,列 2 值,列 3 值)
例子:
insert into exam_record values 
(null,'1001','9001','2021-09-01 22:11:12','2021-09-01 23:01:12','90'),
(null,'1002','9002','2021-09-04 07:01:02',null,null)

1.3创建索引

1.3.1 create方式创建索引:

CREATE
[UNIQUE -- 唯一索引
| FULLTEXT -- 全文索引
] INDEX index_name ON table_name -- 不指定唯一或全文时默认普通索引
(column1[(length) [DESC|ASC]] [,column2,...]) -- 可以对多列建立组合索引

例子
create index idx_duration on examination_info(duration);
create unique index uniq_idx_exam_id on examination_info(exam_id);
create fulltext index full_idx_tag on  examination_info(tag);

1.3.2 alter方式创建索引:

ALTER TABLE tb_name ADD [UNIQUE | FULLTEXT] [INDEX] index_content(content)

1.2.1 drop方式删除索引:

DROP INDEX <索引名> ON <表名>

1.2.2 alter方式删除索引:

ALTER TABLE <表名> DROP INDEX <索引名>

1.3.1 索引的使用:

  • 索引使用时满足最左前缀匹配原则,即对于组合索引(col1, col2),在不考虑引擎优化时,条件必须是col1在前col2在后,或者只使用col1,索引才会生效;

  • 索引不包含有NULL值的列
  • 一个查询只使用一次索引,where中如果使用了索引,order by就不会使用
  • like做字段比较时只有前缀确定时才会使用索引
  • 在列上进行运算后不会使用索引,如year(start_time)

二、删

2.1删除库

drop database 数据库名;

2

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值