ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

sql表与索引操作

2022-01-17 22:01:57  阅读:177  来源: 互联网

标签:comment exam record -- 创建 索引 表与 sql table


文章目录

表的创建、修改与删除

表的创建

直接创建表

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;

表的索引的创建、删除

索引的创建

索引的删除

标签:comment,exam,record,--,创建,索引,表与,sql,table
来源: https://blog.csdn.net/qq_43314839/article/details/122547875

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有