码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【MySQL】【牛客-SQL进阶挑战】02 表与索引操作


    文章目录

    • 题目链接
    • 牛客-SQL进阶挑战 02 表与索引操作
      • 表的创建、修改与删除
        • SQL 118 创建一张新表
        • SQL 119 修改表
        • SQL 120 删除表
      • 索引的创建、删除
        • 相关知识点
        • SQL 121 创建索引
        • SQL 122 删除索引


    题目链接

    https://www.nowcoder.com/exam/oj?page=1&tab=SQL%E7%AF%87&topicId=240

    牛客-SQL进阶挑战 02 表与索引操作

    表的创建、修改与删除

    SQL 118 创建一张新表

    CREATE TABLE IF NOT EXISTS user_info_vip (
        id INT(11) PRIMARY KEY AUTO_INCREMENT COMMENT '自增ID',
        uid INT(11) UNIQUE NOT NULL COMMENT '用户ID',
        nick_name VARCHAR(64) COMMENT '昵称',
        achievement INT(11) DEFAULT 0 COMMENT '成就值',
        `level` INT(11) COMMENT '用户等级',
        job VARCHAR(32) COMMENT '职业方向',
        register_time DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '注册时间'
    );
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    SQL 119 修改表

    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 achievement INT(11) DEFAULT 0;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    SQL 120 删除表

    DROP TABLE IF EXISTS exam_record_2011,
    exam_record_2012,
    exam_record_2013,
    exam_record_2014;
    
    • 1
    • 2
    • 3
    • 4

    索引的创建、删除

    相关知识点

    索引的优点:MySQL索引的建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL的检索速度。

    创建索引时,你需要确保该索引是应用在 SQL 查询语句的条件(一般作为 WHERE 子句的条件)。

    实际上,索引也是一张表,该表保存了主键与索引字段,并指向实体表的记录。上面都在说使用索引的好处,但过多的使用索引将会造成滥用。因此索引也会有它的缺点:

    • 虽然索引大大提高了查询速度,同时却会降低更新表的速度,如对表进行INSERT、UPDATE和DELETE。因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。

    • 建立索引会占用磁盘空间的索引文件。

    CREATE方式创建索引

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

    ALTER方式创建索引

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

    DROP方式创建索引

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

    ALTER方式删除索引

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

    SQL 121 创建索引

    CREATE UNIQUE INDEX uniq_idx_exam_id ON examination_info(exam_id);
    CREATE FULLTEXT INDEX full_idx_tag ON examination_info (tag);
    CREATE INDEX idx_duration ON examination_info(duration);
    
    • 1
    • 2
    • 3

    SQL 122 删除索引

    DROP INDEX uniq_idx_exam_id ON examination_info;
    DROP INDEX full_idx_tag ON examination_info;
    
    • 1
    • 2
  • 相关阅读:
    怎么给字符串新增方法?
    Python的单元测试之unittest
    Redis的分布式锁问题(九)Redis + Lua 脚本实现分布式锁
    Docker中出现bash: vim: command not found解决方案
    MySQL导致索引失效的情况详解
    form-create的基本使用
    版本控制 Sourcetree
    (仿牛客社区项目)Java开发笔记7.9:优化网站的性能
    【操作系统】同步、通信与死锁2
    Unity UGUI 循环滑动列表实现思路及简单代码实现
  • 原文地址:https://blog.csdn.net/guliguliguliguli/article/details/126329213
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号