• 09数据库复习03


    1.索引

    -- 创建普通索引
    CREATE TABLE test4(
        id TINYINT UNSIGNED,
        username VARCHAR(20),
        INDEX in_id(id),
        KEY in_user(username)
    );
    
    -- 创建唯一性索引
    CREATE TABLE test5(
        id TINYINT UNSIGNED AUTO_INCREMENT KEY,
        username VARCHAR(20) NOT NULL UNIQUE,
        card CHAR(18) NOT NULL,
        UNIQUE KEY uni_card(card)
    );
    
    -- 创建全文索引
    CREATE TABLE test6(
        id TINYINT UNSIGNED AUTO_INCREMENT KEY,
        username VARCHAR(20) NOT NULL UNIQUE,
        userdesc VARCHAR(200) NOT NULL,
        FULLTEXT INDEX full_userDesc(userdesc)
    );
    
    -- 创建单列索引
    CREATE TABLE test7(
        id TINYINT UNSIGNED AUTO_INCREMENT KEY,
        t1 VARCHAR(20) NOT NULL,
        t2 VARCHAR(20) NOT NULL,
        t3 VARCHAR(20) NOT NULL,
        t4 VARCHAR(20) NOT NULL,
        INDEX in_t1(t1)
    );
    
    -- 创建多列索引
    CREATE TABLE test8(
        id TINYINT UNSIGNED AUTO_INCREMENT KEY,
        t1 VARCHAR(20) NOT NULL,
        t2 VARCHAR(20) NOT NULL,
        t3 VARCHAR(20) NOT NULL,
        t4 VARCHAR(20) NOT NULL,
        INDEX mul_t1_t2_t3(t1,t2,t3)
    );
    
    -- 创建唯一性的多列索引
    CREATE TABLE test9(
        id TINYINT UNSIGNED AUTO_INCREMENT KEY,
        t1 VARCHAR(20) NOT NULL,
        t2 VARCHAR(20) NOT NULL,
        t3 VARCHAR(20) NOT NULL,
        t4 VARCHAR(20) NOT NULL,
        UNIQUE KEY  mul_t1_t2_t3(t1,t2,t3)
    );
    DROP INDEX in_id ON test4;

    DROP INDEX in_user ON test4;

    -- 在已存在的表上添加索引
    CREATE INDEX in_id ON test4(id);

    ALTER TABLE test4 ADD INDEX in_username(username);

    2.视图

    2.1视图的概念

    视图又被称为虚拟表,视图(view)是sql的查询结果。

    2.2作用

    1.权限控制时可以使用:
    比如某几个列,允许用户查询,其他列不允许。可以通过视图,开放其中一列或几列,起到权限控制的作用

    CREATE VIEW v2 AS SELECT goods.`goods_id`,goods.`goods_name`,goods.`shop_price` FROM goods;
    
    SELECT * FROM v2;

    2.简化复杂的查询:

    一个查询语句本来就很复杂了,还要在外层继续嵌套。
    查询每个栏目下商品的平均价格,并按平均价格排序,查出平均价格前三的商品:

    CREATE VIEW v3 AS  
        SELECT cat_id,AVG(shop_price)  AS pj
        FROM goods GROUP BY cat_id;
    
    SELECT * FROM v3 ORDER BY pj DESC LIMIT 0,3;
  • 相关阅读:
    在类的外面调用类的private函数
    Django多表操作
    Django聚合与分组查询中value与annotate的顺序问题
    Django路由控制
    cookie与session的区别与关系
    面试题之改变对象的类
    python实现双向链表
    python实现单向循环链表
    python中的顺序表
    顺序表
  • 原文地址:https://www.cnblogs.com/xinmomoyan/p/11436560.html
Copyright © 2020-2023  润新知