首页 > 数据库 >MySQL基础-SQL-DDL

MySQL基础-SQL-DDL

时间:2023-01-30 18:34:29浏览次数:36  
标签:COMMENT SQL DDL 表名 字段 emp MySQL TABLE ALTER

1. SQL通用语法 

  1. SQL语句可以单行或多行书写,以分号结尾。
  2. SQL语句可以使用空格/缩进来增强语句的可读性。
  3. MySQL数据库的SQL语句不区分大小写,关键字建议大写。
  4. 注释:
    单行注释: -- 注释内容 或 # 注释内容(MySQL特有)
    多行注释: /* 注释内容 */

2. SQL分类

DDL Data Definition Language  

   数据定义语言,用来定义数据库对象(数据库、表、字段)
DML Data Manipulation Language  

  数据操作语言,用来对数据库表中的数据进行增删改
DQL Data Query Language

   数据查询语言,用来查询数据库中表的数据
DCL Data Control Language

   数据控制语言,用来创建数据库用户、控制数据库的访问权限

3. 字段类型

3.1 数据类型

3.2 字符串类型

3.3 日期类型

 

 案例: 

根据需求创建表(设计合理的数据类型)、
设计一张员工信息表,要求如下:
  1. 编号(纯数字)
  2. 员工工号(字符串类型,长度不超过10位)
  3. 员工姓名(字符串类型,长度不超过10位)
  4. 性别(男/女,存储1个汉字)
  5. 年龄(正常人年龄,不可能存储负数)
  6. 身份证号(二代身份证号均为18位,身份证中有X这样的字符)
  7. 入职时间(取值年月日即可)

 SQL语句:
CREATE TABLE emp(
	id INT COMMENT '编号',
	work_id VARCHAR(10) COMMENT '员工工号',
	name VARCHAR(10) COMMENT '员工姓名',
	gender CHAR(1) COMMENT '性别',
	age TINYINT UNSIGNED COMMENT '年龄',
	idcard CHAR(18) COMMENT '身份证号',
	entrydate DATE COMMENT '入职时间'
)COMMENT '员工表';

4. DDL

4.1 DDL-库操作
4.1.1 库查询
查询所有数据库
SHOW DATABASES;
查询当前数据库
SELECT DATABASE();
4.1.2 库创建
CREATE DATABASE [IF NOT EXITS] 数据库名 [DEFAULT CHARSET 字符集][COLLATE 排序规则];
4.1.3 库删除
DROP DATABES [IF EXITS] 数据库名;
4.1.4 库使用
USE 数据库名;
4.2 DDL-表操作
4.2.1 表查询
查询当前数据库所有表;
SHOW TABLES;
查询表结构
DESC 表名;
查询指定表的创建语句
SHOW CREATE TABLE 表名;
4.2.2 表创建
	CREATE TABLE 表名(
		字段1 字段1类型[COMMENT 字段1注释],
		字段2 字段2类型[COMMENT 字段2注释],
		字段3 字段3类型[COMMENT 字段3注释],
		......
		字段n 字段n类型[COMMENT 字段n注释]
)[COMMENT 表注释]
4.2.3 表修改

添加字段

ALTER TBALE 表名 ADD 字段名 类型(长度)[COMMENT 注释][约束];

  案例:

    为emp表增加一个新的字段"昵称"为nickname,类型为varchar(20)

ALTER TABLE emp ADD nickname VARCHAR(20) COMMENT '昵称';

修改数据类型

ALTER TABLE 表名 MODIFY 字段名 新数据类型(长度);

修改字段名和字段类型

ALTER TABLE 表名 CHANGE 旧字段名 新字段名 类型(长度)[COMMENT 注释][约束];

  案例:

    将emp表的nickname字段修改为username,类型为varchar(30);

ALTER TABLE emp CHANGE nickname username VARCHAR(30) COMMENT '用户名';
4.2.4 表删除
表字段删除
ALTER TABLE 表名 DROP 字段名;

  案例:

    将emp表的字段username删除

ALTER TABLE emp DROP username;
删除表
删除表
DROP TBALE [IF EXITS] 表名;
删除指定表,并重新创建该表
TRUNCATE TABLE 表名;
注意:

  在删除表时,表里面的数据也会被删除

4.2.5 修改表名
ALTER TABLE 表名 RENAME TO 新表名;

  案例:

    将emp表的表名修改为employee

ALTER TABLE emp RENAME TO employee;

标签:COMMENT,SQL,DDL,表名,字段,emp,MySQL,TABLE,ALTER
From: https://www.cnblogs.com/xmtxh/p/17076950.html

相关文章

  • MySql慢查询
    一、简介开启慢查询日志,可以让MySQL记录下查询超过指定时间的语句,通过定位分析性能的瓶颈,才能更好的优化数据库系统的性能。开发环境建议一直开启便与优化生成环境建议关......
  • SQL改写案例3(标量子查询改写的各种姿势)
    同事提供一条SQL,原执行时间需要3.6S,反馈比较慢需要优化一下,废话不说贴SQL:原SQL:select((selectcount(1)FROMwf_bus_instancewfjoin......
  • mac m1使用oracle sqlplus
    环境macstudio(2022)ChipAppleM1Maxoracle官网https://www.oracle.com/database/technologies/instant-client/macos-intel-x86-downloads.html只有Intelx86的......
  • flask_migrate---处理 sqlalchemy 数据迁移的工具
    1.什么是flask_migrateflask_migrate是专门用来做sqlalchemy数据迁移的工具,当据模型发生变化的时可将修改后的模型重新映射到数据库中,这意味着数据库也将被修改。本文介......
  • MySql sql_mode
    sql_mode默认值是空值,在默认值设置下是可以允许一些非法操作,比如允许写入一些非法数据,在生产环境中,必须将sql_mode设置为严格模式mysql支持的sql_mode模式:ANSI、TRADITION......
  • SQL、LINQ、Lambda对照表
    SQL、LINQ、Lambda对照表SQLLINQLambdaSELECT*FROMEmployeefromeinEmployeesselecteEmployees.Select()SELECTe.LoginID,e.JobTitleFROMEmployee......
  • SQL Server 安装、配置、迁移 三
    本片博文记录数据迁移。两台电脑,一台IP地址为:10.15.66.168,有名为TestprgDB的数据库,另一台IP地址10.15.66.169,无数据库。本次任务目的为把168电脑的数据库拷贝到169电脑。......
  • Sql语句的执行数据是什么?
    SQLSelect语句完整的执行顺序:1、from子句组装来自不同数据源的数据;2、where子句基于指定的条件对记录行进行筛选;3、groupby子句将数据划分为多个分组;4、使用聚集函数......
  • mysql8.0远程访问配置
    mysql8.0远程访问配置一、修改bind-address查找配置文件my.confwhichmysql/usr/bin/mysql--verbose--help|grep-A1'Defaultoptions'vimy.cnfbind-addres......
  • 【Amadeus原创】MySQL8设置root用户远程访问
    1.查询当前root状态,默认root的host是localhostusemysql;selectuser,hostfromuser;2.updateroot的host为%updateusersethost='%'whereuser='root';3.检查客......