sql表与索引操作
2022/1/18 2:04:55
本文主要是介绍sql表与索引操作,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
文章目录
- 表的创建、修改与删除
- 表的创建
- 直接创建表
- 从另一张表复制其表结构来创建表
- 从另一张表的查询结果来创建表
- 表的修改
- 表的删除
- 表的索引的创建、删除
- 索引的创建
- 索引的删除
表的创建、修改与删除
表的创建
直接创建表
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] -- 字符集编码,例:CHARACTER SET utf-8 或 default charset=utf8 [COLLATE collate_value] -- 列排序和比较时的规则(是否区分大小写等)
注意:“|”表示 或,[…|…|…|…]的内容顺序随便。
题目:https://www.nowcoder.com/practice/a61ee5519d14444aa99e530309a8e043?tpId=240&tags=&title=&difficulty=0&judgeStatus=0&rp=0
create table if not exists user_info_vip( id int primary key auto_increment comment "自增ID", # 由于id是自增的,不会为NULL,所以即便题中有要求也不要写NOT NULL. # id int not null primary key auto_increment comment "自增ID", uid int not null unique 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
从另一张表复制其表结构来创建表
CREATE TABLE tb_name LIKE tb_name_old
从另一张表的查询结果来创建表
CREATE TABLE tb_name AS SELECT * FROM tb_name_old WHERE option
表的修改
ALTER TABLE 表名 修改选项 。
选项集合:
{ ADD COLUMN <列名> <类型> [after|first 新列名] -- 增加列 | CHANGE <旧列名> <新列名> <新列类型> -- 修改列名或类型 | MODIFY COLUMN <列名> <类型> [新约束] -- 修改列类型或增加约束 | DROP COLUMN <列名> -- 删除列 | RENAME [TO] <新表名> -- 修改表名 | CHARACTER SET <字符集名> -- 修改字符集 | COLLATE <校对规则名> } -- 修改校对规则(比较和排序时用到)
题目:https://www.nowcoder.com/practice/d08209df6f464cebafda5dfd5de03fce?tpId=240&tags=&title=&difficulty=0&judgeStatus=0&rp=0
法1:
alter table user_info add column school varchar(15) after level; alter table user_info change column job profession varchar(10); alter table user_info modify column achievement int(11) default 0;
法2:
alter table user_info add school varchar(15) after level, change job profession varchar(10), # modify column achievement int(11) default 0; change achievement achievement int(11) default 0; # 用change也可以
注意:
1.对某列修改或添加默认值必须先写上该列的类型
。
2.列名前不加“column”也OK。
表的删除
DROP TABLE [IF EXISTS] 表名1 [ ,表名2]
题:https://www.nowcoder.com/practice/df2f634a53324bbd9369fe6723fedc49?tpId=240&tags=&title=&difficulty=0&judgeStatus=0&rp=0
drop table if exists exam_record_2011,exam_record_2012,exam_record_2013,exam_record_2014
或
drop table if exists exam_record_2011; drop table if exists exam_record_2012; drop table if exists exam_record_2013; drop table if exists exam_record_2014;
表的索引的创建、删除
索引的创建
索引的删除
这篇关于sql表与索引操作的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23Springboot应用的多环境打包入门
- 2024-11-23Springboot应用的生产发布入门教程
- 2024-11-23Python编程入门指南
- 2024-11-23Java创业入门:从零开始的编程之旅
- 2024-11-23Java创业入门:新手必读的Java编程与创业指南
- 2024-11-23Java对接阿里云智能语音服务入门详解
- 2024-11-23Java对接阿里云智能语音服务入门教程
- 2024-11-23JAVA对接阿里云智能语音服务入门教程
- 2024-11-23Java副业入门:初学者的简单教程
- 2024-11-23JAVA副业入门:初学者的实战指南