galaxy
  • Introduction
  • knowledge
    • JAVA
      • 多态
      • Socket
      • Servlet
      • HashMap
      • TCP
      • DelayQueue
      • Java反射
      • Java Proxy 和 CGLIB 动态代理
      • JVM
        • 类生命周期
        • JVM内存模型
        • 类加载器与双亲委派模型
        • JVM中堆和栈的区别
      • java.time
    • Spring
      • 常用注解
        • @Transactional
      • Spring Data JPA
      • AOP
      • IOC/DI
      • Spring 事务
      • Spring Boot 启动原理解析
      • Spring MVC
        • Spring MVC 2
      • MVC
    • 分布式
      • RPC框架
      • MQ
      • dubbo
        • 环境部署
        • demo
      • 分布式RPC框架性能大比拼
      • 序列化
      • ZK
        • 本地安装zk
        • ZK详解
      • 分布式
        • 分布式锁
      • 限流熔断技术
    • DB
      • Mysql
        • 索引
      • 事务
      • 数据库连接池
        • 工作原理
        • 连接池技术背景
        • 百度百科
        • 主流数据库连接池
      • MongoDB
        • 适用场景
        • MongoDB Java异步驱动快速指南
        • 异步Mongo驱动的性能测试
        • 使用规范
        • 使用场景2
      • Spring Data JPA
      • 数据库设计三大范式
      • 存储过程
      • 视图
      • 乐观锁与悲观锁
      • 分库分表
      • Redis3
        • 其它
        • Redis
        • 场景
        • 分布式及其它
    • Test
      • NGrinder
      • QPS与并发数
    • 并发编程
      • volatitle
      • 锁
      • ThreadLocal
      • AQS
      • CAS
      • RateLimiter
    • 线程池
      • Executors
      • ScheduledThreadPoolExecutor
      • 终止线程池原理
      • demo
  • MST目录
    • 算法&数据结构
      • 算法
      • 数据结构
      • 算法题
      • 经典算法
  • Tool
    • Git
    • Netty5
      • 一些案例
      • Netty源码分析
        • 一、服务器绑定过程分析
        • 二、线程模型分析
        • 三、Channel如何注册OP_ACCEPT, OP_READ, OP_WRITE
        • 四、事件分发模型
        • 五、ByteBuf缓冲区
        • 六、CodeC编解码分析
        • 七、异步执行Future和Promise
      • Netty5.0架构剖析和源码解读
    • idea
  • issue
    • Connection reset
    • 该如何从 Java 8 升级到 Java 10
    • 阿里巴巴为什么不用 ZooKeeper 做服务发现
  • Linux
    • command
Powered by GitBook
On this page

Was this helpful?

  1. knowledge
  2. DB

Mysql

PreviousDBNext索引

Last updated 6 years ago

Was this helpful?

一、

参考网址:

常见面试题:

1、只复制表结构到新表

CREATE TABLE 新表 LIKE 旧表 ;

2、复制表结构及数据到新表

CREATE TABLE 新表 SELECT * FROM 旧表

二、查询数据带分页

select * from orders_history where type=8 order by id limit 10000,10;

3、将t2表的查询结果插入到t1表中

INSERT INTO t1(id,username,score)
SELECT t2.id,t2.username,t2.score FROM t2 where t2.username = 'lucy'

4、表联合更新

UPDATE t_zeus_apply a,
    t_zeus_provider_ref b 
SET 
    a.city_id = b.city_id,
    a.city_name = b.city_name
WHERE
    a.supplier_company_id = b.supplier_company_id;

5、Case When THEN END 用法

SELECT 
    apply_id,
    CASE
        WHEN status = 20 THEN '审核通过'
        WHEN status = 30 THEN '审核拒绝'
        WHEN status = 40 THEN '审核撤销'
        WHEN status = 10 THEN '审核中'
        ELSE '其它'
    END status,
    state_name
FROM
    t_zeus_apply
ORDER BY apply_id;

6、加字段

alter table t_zeus_apply add `city_id` bigint(20) NOT NULL DEFAULT '0' COMMENT '城市id';
alter table domino_instance add `source` varchar(50) NOT NULL DEFAULT '' COMMENT '来源';

7、修改字段

alter table domino_transfer modify column `notify` varchar(50) NOT NULL DEFAULT '' COMMENT '事件标识';

8、条件查询

SELECT
    COUNT(*) AS total,
    SUM(IF(state_code =  "WANSHANZILIAO", 1, 0)) AS 待上传资料总数,
    SUM(IF(state_code =  "WANSHANZILIAO", 1, 0)) AS 待上传资料总数,
    SUM(IF(state_code = "BUCHONGZILIAO", 1, 0)) AS 审核驳回总数,
    SUM(IF(state_code = "FENGKONGMOXINGSHENHE", 1, 0)) AS 待系统审核总数,
    SUM(IF(state_code = "SHANGCHUANXIANCHANGZHOUYANBAOGAO", 1, 0)) AS 待城市审核总数,
    SUM(IF(state_code = "FENGKONGCHUSHEN", 1, 0)) AS 待风控初审总数,
    SUM(IF(state_code = "FENGKONGRENGONGSHENHE", 1, 0)) AS 待风控复审总数,
    SUM(IF(state_code = "ZONGBUSHENHE", 1, 0)) AS 待总部审核总数,
    SUM(IF(state_code = "SHANGCHUANHETONGHUOBAOZHENGJIN", 1, 0)) AS 待准入凭证上传总数,
    SUM(IF(state_code = "ZONGBUQUEREN", 1, 0)) AS 待总部确认总数
FROM
    t_zeus_apply

9、条件查询二维

SELECT city_name as 所属城市,
SUM(IF(state_code = "WANSHANZILIAO", 1, 0)) AS 待上传资料总数,
SUM(IF(state_code = "BUCHONGZILIAO", 1, 0)) AS 审核驳回总数,
SUM(IF(state_code = "FENGKONGMOXINGSHENHE", 1, 0)) AS 待系统审核总数,
SUM(IF(state_code = "SHANGCHUANXIANCHANGZHOUYANBAOGAO", 1, 0)) AS 待城市审核总数,
SUM(IF(state_code = "SHANGCHUANHETONGHUOBAOZHENGJIN", 1, 0)) AS 待准入凭证上传总数
FROM
t_zeus_apply where city_id != 4 group by city_name;

9、length

SELECT LENGTH('www.111cn.net');

10、近N天

今天:select * from 表名 where to_days(时间字段名) = to_days(now());
昨天:SELECT * FROM 表名 WHERE TO_DAYS( NOW( ) ) - TO_DAYS( 时间字段名) <= 1;
近7天:SELECT * FROM 表名 where DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(时间字段名);
近30天:SELECT * FROM 表名 where DATE_SUB(CURDATE(), INTERVAL 30 DAY) <= date(时间字段名);
本月:SELECT * FROM 表名 WHERE DATE_FORMAT( 时间字段名, '%Y%m' ) = DATE_FORMAT( CURDATE( ) , '%Y%m' );
上一月:SELECT * FROM 表名 WHERE PERIOD_DIFF(date_format(now( ), '%Y%m' ) , date_format( 时间字段名,'%Y%m')) =1;
本季度:select * from `ht_invoice_information` where QUARTER(create_date)=QUARTER(now());
上季度:select * from `ht_invoice_information` where QUARTER(create_date)=QUARTER(DATE_SUB(now(),interval 1 QUARTER));
本年:select * from `ht_invoice_information` where YEAR(create_date)=YEAR(NOW());
上年:select * from `ht_invoice_information` where year(create_date)=year(date_sub(now(),interval 1 year));
这周:SELECT name,submittime FROM enterprise WHERE YEARWEEK(date_format(submittime,'%Y-%m-%d')) = YEARWEEK(now());
上周:SELECT name,submittime FROM enterprise WHERE YEARWEEK(date_format(submittime,'%Y-%m-%d')) = YEARWEEK(now())-1;
当月:select name,submittime from enterprise   where date_format(submittime,'%Y-%m')=date_format(now(),'%Y-%m')

11、distinct 多列

INSERT INTO t1(id,username,score)
SELECT t2.id,t2.username,t2.score FROM t2 where t2.username = 'lucy' group by t2.username;
MySQL用命令行复制表的方法
https://www.cnblogs.com/zhangjpn/p/6231662.html
https://www.cnblogs.com/frankielf0921/p/5930743.html