• mysql对表的操作


    创建表

    简单的方式

    CREATE TABLE person (
    number INT(11),
    name VARCHAR(255),
    birthday DATE
    );
    或者是

    CREATE TABLE IF NOT EXISTS person (
    number INT(11),
    name VARCHAR(255),
    birthday DATE
    );


    查看mysql创建表:
    语句:SHOW CREATE table person;

    结果:
    CREATE TABLE person (
    number int(11) DEFAULT NULL,
    name varchar(255) DEFAULT NULL,
    birthday date DEFAULT NULL
    ) ENGINE=MyISAM DEFAULT CHARSET=utf8;

    查看表所有的列:
    SHOW FULL COLUMNS from person;


    创建临时表

    CREATE TEMPORARY TABLE temp_person (
    number INT(11),
    name VARCHAR(255),
    birthday DATE
    );

    在创建表格时,您可以使用TEMPORARY关键词。只有在当前连接情况下,TEMPORARY表才是可见的。当连接关闭时,TEMPORARY表被自动取消。这意味着两个不同的连接可以使用相同的临时表名称,同时两个临时表不会互相冲突,也不与原有的同名的非临时表冲突。(原有的表被隐藏,直到临时表被取消时为止。)您必须拥有CREATE TEMPORARY TABLES权限,才能创建临时表。


    如果表已存在,则使用关键词IF NOT EXISTS可以防止发生错误。
    CREATE TABLE IF NOT EXISTS person2 (
    number INT(11),
    name VARCHAR(255),
    birthday DATE
    );
    注意,原有表的结构与CREATE TABLE语句中表示的表的结构是否相同,这一点没有验证。注释:如果您在CREATE TABLE…SELECT语句中使用IF NOT EXISTS,则不论表是否已存在,由SELECT部分选择的记录都会被插入。


    在CREATE TABLE语句的末尾添加一个SELECT语句,在一个表的基础上创建表
    CREATE TABLE new_tbl SELECT * FROM orig_tbl;
    注意,用SELECT语句创建的列附在表的右侧,而不是覆盖在表上
    mysql> SELECT * FROM foo;
    +—+
    | n |
    +—+
    | 1 |
    +—+
    mysql> CREATE TABLE bar (m INT) SELECT n FROM foo;
    mysql> SELECT * FROM bar;
    +——+—+
    | m | n |
    +——+—+
    | NULL | 1 |
    +——+—+


    也可以明确地为一个已生成的列指定类型
    CREATE TABLE foo (a TINYINT NOT NULL) SELECT b+1 AS a FROM bar;


    根据其它表的定义(包括在原表中定义的所有的列属性和索引),使用LIKE创建一个空表:
    CREATE TABLE new_tbl LIKE orig_tbl;


    创建一个有主键,唯一索引,普通索引的表:
    CREATE TABLE people (
    peopleid smallint(6) NOT NULL AUTO_INCREMENT,
    firstname char(50) NOT NULL,
    lastname char(50) NOT NULL,
    age smallint(6) NOT NULL,
    townid smallint(6) NOT NULL,
    PRIMARY KEY (peopleid),
    UNIQUE KEY unique_fname_lname(firstname,lastname),
    KEY fname_lname_age (firstname,lastname,age)
    ) ;
    其中peopleid是主键,以firstname和lastname两列建立了一个唯一索引,以firstname,lastname,age三列建立了一个普通索引


    删除表

    DROP TABLE tbl_name;
    或者是

    DROP TABLE IF EXISTS tbl_name;

    --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

    查询表中不重复的数据,使用distinct:

    例如选取表中所有的数据

    select distinct *from table_name

  • 相关阅读:
    Maven插件系列之spring-boot-maven-plugin
    Java中getResourceAsStream的用法
    【redis】【linux】-bash: redis-cli: 未找到命令
    【bat】杀死指定端口
    【bat】查看端口占用情况
    【java】【springboot】nohup: 无法运行命令'java': 没有那个文件或目录
    【springboot】启动指定内存大小
    【java】【spring】源码分析,@AliasFor互为别名
    【idea】设置安装插件位置
    【记录】【springboot】java.lang.NoClassDefFoundError: org/w3c/dom/ElementTraversal解决
  • 原文地址:https://www.cnblogs.com/nyist-xsk/p/7264776.html
Copyright © 2020-2023  润新知