约束

  • 主键约束

    • primary key
    • primary key(字段名...)
  • 外键约束

    constraint fk_table1_table2 foreign key(字段) references table2(字段)
  • 其它约束

    • unique
    • not null
    • default
    • auto_increment
    CREATE TABLE t_emp(
    id INT PRIMARY KEY auto_increment,
    name VARCHAR(22) not null unique,
    sex VARCHAR(2) DEFAULT '男'
    ) DEFAULT CHARSET=utf8;

表操作

查看表结构与修改表名

  • 查看数据表基本结构

    desc 表名
  • 查看数据表详细结构

    show create table 表名 \G

    不仅可以返回给我们建表时所写的详细语句,而且还可以查看存储引擎和字符编码

  • 修改表名

    ALTER TABLE 旧表名 RENAME 新表名;

修改字段名与字段数据类型

  • 修改字段名

    ALTER TABLE 表名 CHANGE 旧字段名 新字段名 新数据类型;
  • 修改字段数据类型

    ALTER TABLE 表名 MODIFY 字段名 数据类型;

添加与删除字段

  • first 在表的第一列添加字段
  • after 在表的指定列后添加字段
  • drop 删除字段

修改字段的排列位置

  • ALTER TABLE 表名 MODIFY 字段1 数据类型 FIRST|AFTER 字段2;

删除表的外键约束

  • ALTER TABLE 表名 DROP FOREIGN KEY 外键约束名;

增删改

插入数据

INSERT INTO 表名 (字段名) VALUES (内容), (内容), (内容)...;

更新数据

UPDATE 表名 SET 字段名1 = 内容1, 字段名2 = 内容2, 字段名3 = 内容3 WHERE 过滤条件;

删除数据

  •  DELETE FROM 表名 WHERE 条件语句;
  • 清空表

    TRUNCATE 表名

查询

单表查询

  • SELECT 字段名 FROM 表名;
  • 带in关键字的查询

     SELECT 字段名 FROM 表名 WHERE 字段名 (not) IN (n1,n2,n3,...);
    • 范围查询

       SELECT 字段名 FROM 表名 WHERE 字段名 (not) BETWEEN n1 AND n2;
    • 带like的字符匹配查询

      1. 使用通配符%模糊匹配数据内容(百分号通配符%可以匹配任意长度的字符,甚至包括零字符。)
      SELECT 字段名 FROM 表名 WHERE 字段名 LIKE '字符%';
      1. 使用通配符_模糊匹配数据内容(下划线通配符_只能模糊匹配1个字符。)
      SELECT 字段名 FROM 表名 WHERE 字段名 LIKE '字符_';
    • 查询空值与去除重复结果

      1. int (not) null
      2. 去重

        SELECT DISTINCT 字段名 FROM 表名;
    • 带 AND 与 OR 的多条件查询

      SELECT 字段名 FROM 表名 WHERE 表达式1 AND / OR 表达式2;
  • 对查询结果进行排序

    SELECT 字段名 FROM 表名 ORDER BY 字段名 [ASC[DESC]];
  • 分组查询

    SELECT 字段名 FROM 表名 GROUP BY 字段名;
  • 限制查询

    SELECT 字段名 FROM 表名 LIMIT [OFFSET,] 记录数;
    1. 第一个参数,OFFSET,可选参数,表示偏移量

    2. 第二个参数,记录数,表示返回查询结果的条数

连接查询

  • 内连接查询

    表1 [inner] join 表2 on 表1.字段=表2.字段
  • 外连接查询

    表1 left/right [outer]  join 表2 on 表1.字段=表2.字段

子查询

  • 带比较运算符的子查询

    eg:
    select name, age from tb_emp where age > (select avg(age) from tb_emp);
  • 关键字子查询

    tb_salary

    id position salary
    1 Java 8000
    2 Java 8400
    3 Java 9000
    4 Python 6500
    5 Python 10000
    #1.使用 ALL 关键字进行查询
    select position, salary from tb_salary where salary > all (select salary from tb_salary where position = 'Java');
    #2.使用 ANY 关键字进行查询
    select position, salary from tb_salary where salary > any (select salary from tb_salary where position = 'Java');
    #3.使用 IN 关键字进行查询
    select position, salary from tb_salary where position in ('Java');

视图

  • 创建视图

    CREATE [OR REPLACE] [ALGORITHM = {UNDEFINED | MERGE | TEMPTABLE}]
    VIEW view_name [(column_list)]
    AS select_statement
    [WITH [CASCADED | LOCAL] CHECK OPTION]
  • 删除视图

    DROP VIEW view_name;

MySQL基本sql语句总结的更多相关文章

  1. Mysql 常用 SQL 语句集锦

    Mysql 常用 SQL 语句集锦 基础篇 //查询时间,友好提示 $sql = "select date_format(create_time, '%Y-%m-%d') as day fr ...

  2. Mysql 常用 SQL 语句集锦 转载(https://gold.xitu.io/post/584e7b298d6d81005456eb53)

    Mysql 常用 SQL 语句集锦 基础篇 //查询时间,友好提示 $sql = "select date_format(create_time, '%Y-%m-%d') as day fr ...

  3. MySQL数据库sql语句的一些简单优化

    1.查询条件的先后顺序 有多个查询条件时,要把效率高能更精确筛选记录的条件放在后边.因为MySQL解析sql语句是从后往前的(不知是否准确). 例: select a.*,b.* from UsrIn ...

  4. mysql下sql语句 update 字段=字段+字符串

    mysql下sql语句 update 字段=字段+字符串   mysql下sql语句令某字段值等于原值加上一个字符串 update 表明 SET 字段= 'feifei' || 字段; (postgr ...

  5. MySQL数据库SQL语句基本操作

    一.用户管理: 创建用户: create user '用户名'@'IP地址' identified by '密码'; 删除用户: drop user '用户名'@'IP地址'; 修改用户: renam ...

  6. mysql执行sql语句过程

    开发人员基本都知道,我们的数据存在数据库中(目前最多的是mysql和oracle,由于作者更擅长mysql,所以这里默认数据库为mysql),服务器通过sql语句将查询数据的请求传入到mysql数据库 ...

  7. MySQL与SQL语句的操作

    MySQL与SQL语句的操作 Mysql比较轻量化,企业用的是Oracle,基本的是熟悉对数据库,数据表,字段,记录的更新与修改 1. mysql基本信息 特殊数据库:information_sche ...

  8. mysql 操作sql语句 目录

    mysql 操作sql语句 操作数据库 mysql 操作sql语句 操作数据表 mysql 操作sql语句 操作数据表中的内容/记录

  9. 不登录到MySQL执行SQL语句

    mysql -e 不登录到MySQL执行SQL语句 mysql -u root -p -e "SHOW DATABASES"

  10. mysql优化sql语句

    mysql优化sql语句   常见误区   www.2cto.com   误区1:   count(1)和count(primary_key) 优于 count(*)   很多人为了统计记录条数,就使 ...

随机推荐

  1. [Python] 网络

    1.应用概念 应用层(Application Layer):将原始信息进行规范化描述,进而通过标准化接口与传输层对接 传输层(Transport Layer):实现信息的切分和重组,以及应用程序间的对 ...

  2. linux进阶之网络技术管理

    本节内容 1.      网络七层模型 物理层 数据链路层 网络层 传输层 会话层 表示层 应用层 2.  TCP/UDP (1)TCP面向连接,可靠传输,消耗系统资源比较多,传输速度较慢,但是数据传 ...

  3. 8.1 fdisk:磁盘分区工具

    fdisk 是Linux下常用的磁盘分区工具.受mbr分区表的限制,fdisk工具只能给小于2TB的磁盘划分分区.如果使用fdisk对大于2TB的磁盘进行分区,虽然可以分区,但其仅识别2TB的空间,所 ...

  4. STM32自己的封装库

    以前一直使用STM32的标准库,需要一步步地将代码加进去,将编译选项设置好,然后再编译整个工程. 这个编译过程是一个相当慢的过程!完全编译大约需要一支烟的时间.每次建立工程都这么编译,是一个相当浪费时 ...

  5. 10.19 dig:域名查询工具

    dig命令 是常用的域名查询工具,可以用于测试域名系统的工作是否正常.  dig命令的参数选项及说明 @<DNS服务器地址>    指定进行城名解析的域名服务器.当不希望使用本机默认的DN ...

  6. IDEA 配置 Tomcat(详细)(Day_12)

    如果这世界上真有奇迹,那只是努力的另一个名字.生命中最难的阶段,不是没有人懂你,而是你不懂你自己. 运行环境 AND 版本 JDK8 + IntelliJ IDEA 2018.3  +   Tomca ...

  7. Python中字符串转换列表

    前言:在使用Python完成工作中一些任务的时候,常常要对数据类型进行转换,比如字符串转列表,列表转字符串,字符串转元组等等,下面分享一下常用的字符串转列表 字符串转列表 第一种字符串转列表: t_s ...

  8. [Django高级之Auth模块]

    [Django高级之Auth模块] auth模块 ←详情点击查看 1.Auth模块是什么 Auth模块是Django自带的用户认证模块: 我们在开发一个网站的时候,无可避免的需要设计实现网站的用户系统 ...

  9. Python+Selenium自动化总结

    Python+Selenium自动化总结 1.环境搭建 1.1.安装selenium模块文件 pip install selenium 1.2.安装ChromeDriver驱动 [1]下载安装Chro ...

  10. Python3.6 的字典为什么会快

    作者:青南链接:https://zhuanlan.zhihu.com/p/73426505来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载请注明出处. 在Python 3.5(含)以 ...