zoukankan      html  css  js  c++  java
  • mysql库和表的管理

    #DDL
    /*
    数据定义语言
    
    库和表的管理
    
    一、库的管理
    创建、修改、删除
    二、表的管理
    创建、修改、删除
    
    创建: create
    修改: alter
    删除: drop
    
    */
    
    #一、库的管理
    #1、库的创建
    /*
    语法:
    create database  [if not exists]库名;
    */
    
    #案例:创建库Books
    
    create databaseif not exists】 库名【 character set 字符集名】;
    CREATE DATABASE IF NOT EXISTS books ;
    
    #2、库的修改
    
    RENAME DATABASE books TO 新库名;
    
    #更改库的字符集
    
    alter database 库名   character set 字符集名;
    ALTER DATABASE books CHARACTER SET gbk;
    
    #3、库的删除
    
    drop databaseif exists】 库名;
    DROP DATABASE  IF EXISTS   books;
    
    #二、表的管理
    #1.表的创建 ★
    
    /*
    语法:
    方式1:
    create table 表名(
        列名 列的类型【(长度) 约束】,
        列名 列的类型【(长度) 约束】,
        列名 列的类型【(长度) 约束】,
        ...
        列名 列的类型【(长度) 约束】
    )
    方式2:使用子查询
     CREATE TABLE 表名
        [(column, column...)]
        AS 子查询;
    
    */
    #案例:创建表Book
    
    create table emp1 as select * from employees;
    
    CREATE TABLE book(
        id INT,#编号
        bName VARCHAR(20),#图书名
        price DOUBLE,#价格
        authorId  INT,#作者编号
        publishDate DATETIME#出版日期
    
    );
    DESC book;
    #案例:创建表author
    CREATE TABLE IF NOT EXISTS author(
        id INT,
        au_name VARCHAR(20),
        nation VARCHAR(10)
    )
    DESC author;
    #2.表的修改
    
    /*
    语法
    alter table 表名 add|drop|modify|change column 列名 【列类型 约束】;
    
    */
    
    #①修改列名,把book表的publishdata列明修改为pubDate。
    
    ALTER TABLE 表名  CHANGE COLUMN 旧列名       新列名   类型;
    ALTER TABLE book CHANGE COLUMN publishdate pubDate DATETIME;
    
    #②修改列的类型或约束
    
    ALTER TABLE 表名  MODIFY COLUMN  列名     新类型 【新约束】;
    ALTER TABLE book MODIFY COLUMN  pubdate TIMESTAMP;
    
    #③添加新列
    
    ALTER TABLE 表名    ADD COLUMN 列名    类型 【first|after 字段名】;
    ALTER TABLE author ADD COLUMN annual DOUBLE; 
    
    #④删除列
    
    ALTER TABLE 表名         DROP COLUMN  列名;
    ALTER TABLE book_author DROP COLUMN  annual;
    
    #⑤修改表名
    
    ALTER TABLE 表名    RENAME 【to】 新表名;
    ALTER TABLE author RENAME  TO    book_author;
    DESC book;
    
    #3.表的删除
    
    DROP TABLEIF EXISTS】 表名;
    DROP TABLE IF EXISTS    book_author;
    
    SHOW TABLES;
    
    #通用的写法:
    
    DROP DATABASE IF EXISTS 旧库名;
    CREATE DATABASE 新库名;
    
    DROP TABLE IF EXISTS 旧表名;
    CREATE TABLE  表名();
    
    #4.表的复制
      1、复制表的结构
        create table 表名 like 旧表;
      2、复制表的结构+数据
        create table 表名
        select 查询列表 from 旧表【where 筛选】;
    
    INSERT INTO author VALUES
    (1,'村上春树','日本'),
    (2,'莫言','中国'),
    (3,'冯唐','中国'),
    (4,'金庸','中国');
    
    SELECT * FROM Author;
    SELECT * FROM copy2;
    #1.仅仅复制表的结构
    
    CREATE TABLE copy LIKE author;
    
    #2.复制表的结构+数据
    CREATE TABLE copy2 
    SELECT * FROM author;
    
    #只复制部分数据
    CREATE TABLE copy3
    SELECT id,au_name
    FROM author 
    WHERE nation='中国';
    
    
    #仅仅复制某些字段
    
    CREATE TABLE copy4 
    SELECT id,au_name
    FROM author
    WHERE 0;//0表示false,1表示true。
  • 相关阅读:
    OA权限管理的实现(下)
    Eclipse及其插件介绍和下载(转)
    [转载]在Redhat Linux AS 4下实现软件RAID
    RAID磁盘阵列术语详解(转)
    [转载]关于"编译器失败,错误代码为128。"的解决方案
    Android的SurfaceView使用
    剖析 SurfaceView Callback以及SurfaceHolder
    android drawable 应用
    Android layout xml总结
    listView控件,adapter,以及其他控件的组合
  • 原文地址:https://www.cnblogs.com/konglxblog/p/14728991.html
Copyright © 2011-2022 走看看