单表查询

 

排序

 
升序
 
  1. select*from表名 order by字段 asc;
 
降序
 
  1. select*from表名 order by字段 desc;
 

条件查询(包括通配符)

 
where语句
 
  1. select*from表名where字段=内容;
  2. select*from表名where字段>=内容and字段<=内容;
  3. select*from表名where字段 between 内容1and内容2;
 
in 语句
 
  1. select*from表名where字段=内容1or字段=内容2;
  2. select*from表名where age in(内容1,内容2);
 
判定字段是否为空
 
  1. select*from表名where字段isnull;//判定字段为空
  2. select*from表名where字段isnotnull;//判定字段不为空
 
not语句
 
  1. select*from表名where字段noin(内容1,内容2);//除了内容1和内容2外的其他内容
 
and or 优先级(and>or)
 
  1. select*from表名where条件1and条件2or条件3;
  2. select*from表名where条件1and(条件2or条件3);
 
like 模糊查询
 
  1. select*from表名where字段 like '%内容%';
  2. select*from表名where字段 like '内容%';
  3. select*from表名where字段 like '%内容';
  4. select*from表名where字段 like '_内容%';//_:下划线是匹配一个任意字符
  5. select*from表名where字段 like '%内容_';//最后第二个字符是内容
 

分组查询(常用mysql函数)

 
group by:将查询结果按照1个或多个字段进行分组,字段值相同的为一组
 
  1. select*fromwhere表名groupby内容1,内容2,内容3......;
 
group_concat(字段名)可以作为一个输出字段来使用
 
  1. select字段1,group_concat(字段2)from表名groupby字段3或字段1或字段2;
 
group by + 集合函数(avg,count用法一样)
 
  1. select字段1,avg(字段2)from表名groupby字段3;
  2. select字段1,count(字段2)from表名groupby字段3;
 

子查询(操作符:=、>、<、>=、<=、<>、any、in、some、all、exists)

 
  1. select*from表名1where字段操作符(select字段1from表名2where条件);
 

分页

 
limit函数
 
  1. select*from表名 limit 0,n;//取前n条数据
  2. select*from表名 limit n;//取前n条数据
  3. select*from表名 limit n,m;//取第(n+1)到(n+m)条数据
 

复制一张表到另一张表中去

 
两张表的字段相同(主键不要有相同内容)
 
  1. insert *from表名1(表名2);
 
两张表的字段不相同(主键不要有相同内容)
 
  1. insert into表名1(字段1,字段2,字段3......)(select字段1,字段2,字段3......from表名2);
 

多表查询(连接查询)

 
交叉连接 cross join(结果集将包括两个表中的所有行)
 
  1. select*from表名1 cross join 表名2;
 
内连接 inner join(只返回两个表中联结字段相等的行)
 
  1. select* form 表名1 inner join 表名2 on 表名1.字段=表名2.字段;
 
左连接(返回包括左表中的所有记录和右表中联结字段相等的记录 )
 
  1. select*from表名1 left join 表名2 on 表名1.字段=表名2.字段;
 
右连接(返回包括右表中的所有记录和左表中联结字段相等的记录)
 
  1. select*from表名1 right join 表名2 on 表名1.字段=表名2.字段;
 
外连接 outer join(外连接就是求两个集合的并集,另外MySQL不支持OUTER JOIN,可以用左连接和右连接的结果做UNION操作来实现)
 
  1. select*from表名1 left join 表名2 on 表名1.字段=表名2.字段
  2. union
  3. select*from表名1 right join 表名2 on 表名1.字段=表名2.字段;
 

索引

 
mysql索引有哪些
 
  1. 主键索引,唯一索引,聚集索引
 
常见(常用)的有哪些
 
  1. 主键索引,唯一索引
 

区别

 
主键索引
 
  1. 唯一索引是不允许其中任何两行具有相同索引值的索引。当现有数据中存在重复的键值时,大多数数据库不允许将新创建的唯一索引与表一起保存。数据库还可能防止添加将在表中创建重复键值的新数据。
 
唯一索引
 
  1. 数据库表经常有一列或多列组合,其值唯一标识表中的每一行。该列称为表的主键。(多列也可以作为主键),主键索引是唯一索引的特定类型。因为唯一索引要求索引列的值不能相同,而主键也都不相同,主键用来区分不同记录,当然不能重复。故主键索引是唯一索引的特殊形式。
  2. 主键索引是数据库自动建立的,只要指定了主键,数据库就会自动创建主键索引。
 
聚集索引
 
  1. 聚集索引中表中行的物理顺序与键值的逻辑(索引)顺序相同。一个表只能包含一个聚集索引。如果某索引不是聚集索引,则表中行的物理顺序与键值的逻辑顺序不匹配。与非聚集索引相比,聚集索引通常提供更快的数据访问速度。
 
基本语句
 
  1. alter from表名 add index 索引名;//添加索引
  2. show index from表名;//查询索引
  3. drop index 索引名 on 表名;//删除索引
+
 
@pfhu 2018-05-07 18:08 字数 2222 阅读 18

数据库(mysql)相关知识的更多相关文章

  1. 数据库 MySQL基础知识

    (关于MySQL的安装,具体见下面博客:http://www.cnblogs.com/wj-1314/p/7573242.html) 一.什么是数据库 ? 数据库是按照数据结构来组织,存储和管理数据的 ...

  2. MySQL相关知识

    字符串拼接 select * from tablename where mydata like CONCAT(CURDATE(), '%') limit 3 这里concat是字符串拼接, conca ...

  3. MySQL相关知识总结

    1. 显示所有表 show tables; 还有information_schema数据库里面有tables表,记录了所有表信息 use information_schema; select * fr ...

  4. 数据库 —— mySQL相关

    目录 使用笔记 问题解决 资源链接 1.使用笔记 1.命令行客户端显示无法调整表格显示宽度,可以考虑在查询语句尾后添加 \G; 2.插入语句字符串转时间:link 2.问题解决 1.不能显示插入中文字 ...

  5. Spring的事务管理和数据库事务相关知识

    1 初步理解 理解事务之前,先讲一个你日常生活中最常干的事:取钱.         比如你去ATM机取1000块钱,大体有两个步骤:首先输入密码金额,银行卡扣掉1000元钱:然后ATM出1000元钱. ...

  6. Mysql相关知识总结-持续更新~~~

    2019-12-11对varchar类型排序问题的解决 在mysql默认order by 只对数字与日期类型可以排序,但对于varchar字符型类型排序好像没有用了,下面我来给各位同学介绍varcha ...

  7. MySQL 相关知识细节及解析

    1,删除表中所有记录使用delete from 表名:还是用truncate table 表名 删除方式:delete 一条一条删除,不清空auto_increment记录数 truncate 直接将 ...

  8. 基于C#的MongoDB数据库开发应用(1)--MongoDB数据库的基础知识和使用

    在花了不少时间研究学习了MongoDB数据库的相关知识,以及利用C#对MongoDB数据库的封装.测试应用后,决定花一些时间来总结一下最近的研究心得,把这个数据库的应用单独作为一个系列来介绍,希望从各 ...

  9. 数据库相关知识积累(sqlserver、oracle、mysql)

    数据库相关知识积累(sqlserver.oracle.mysql) 1. sqlserver :断开所有连接: (还原数据库) 1.数据库  分离 2. USE master GO ALTER DAT ...

  10. 数据库与sql注入的相关知识

    数据库与sql注入的相关知识 sql语句明显是针对数据库的一种操作,既然想通过sql注入的方法来拿取数据那么就要先了解一下如何的去操作数据库,这方面并不需要对数据库有多么的精通但是如果了解掌握了其中的 ...

随机推荐

  1. 古韵之乞巧 题解 dp题

    [noip模拟赛1]古韵之乞巧   描述 闺女求天女,更阑意未阑. 玉庭开粉席,罗袖捧金盘. 向月穿针易,临风整线难. 不知谁得巧,明旦试相看. ——祖咏<七夕> 女子乞巧,是七夕的重头戏 ...

  2. HashMap、Hashtable、ConcurrentHashMap的原理与区别(简述)

    HashTable 底层数组+链表实现,无论key还是value都不能为null,线程安全,实现线程安全的方式是在修改数据时锁住整个HashTable,效率低,ConcurrentHashMap做了相 ...

  3. Android 8.0+ 更新安装apk失败的问题

    最近做项目发现Android 8.0+ 更新安装apk时 出现安装失败的情况  总结原因是 缺少安装的权限 Android 8.0 (Android O)为了针对一些流氓软件引导用户安装其他无关应用. ...

  4. 大数据学习(一)-------- HDFS

    需要精通java开发,有一定linux基础. 1.简介 大数据就是对海量数据进行数据挖掘. 已经有了很多框架方便使用,常用的有hadoop,storm,spark,flink等,辅助框架hive,ka ...

  5. 使用tcpcopy复制线上流量进行测试

    使用tcpcopy复制线上流量进行测试 online server 线上服务所在机器 10.136.11.4 部署tcpcopy sudo /usr/local/tcpcopy/sbin/tcpcop ...

  6. 配置GitHub的SSH key

    配置GitHub的SSH key 生成密钥对 打开git bash工具(Windows环境),Linux则直接打开命令行,执行下面的命令生成密钥文件 ssh-Keygen -t rsa -C &quo ...

  7. Node.js server-side javascript cpu占用高

    也不知道微软咋想的,不搞死我们的电脑不罢休 https://developercommunity.visualstudio.com/content/problem/27033/nodejs-serve ...

  8. Python学习——1

    我是一名刚入IT行业的小白,目前主要是做网络运维这一块.曾经总是认为我是做网络运维的,学习代码干啥啊?后来就慢慢发现,传统的运维方式让我的效率好像不如别人效率高,关键还TM看别人比我更轻松.每一个网络 ...

  9. 从零开始学java (四)反射

    反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意一个方法和属性:这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反射机制. ...

  10. 微信小程序开发之搞懂flex布局4——Main Axis

    Main Axis——主轴 当flex-direction设置为row或row-reverse时,主轴的方向为水平方向.此时flex item为行内级元素. 当flex-direction设置为col ...