熟悉

我熟悉xxx,其实很多原来熟悉到能背的,如果长时间不用了几乎也就忘了。此时再说自己熟悉XXX就被认为是在吹牛B了,感觉不是很好。所谓温故而知新,对于天资不聪颖的,就是要在一遍一遍的复习实践中慢慢理解掌握、获取别人可能一天就就明白记住的事情。

查看建表语句

show create table table_name;

复制表

根据已有的表新建一张表,可以使用

CREATE TABLE new_table_name SELECT * FROM old_table_name;

如一张表为Person如下:

mysql> select * from Person;
+----+------------------+
| Id | Email |
+----+------------------+
| 1 | john@example.com |
| 2 | bob@example.com |
| 3 | john@example.com |
+----+------------------+
3 rows in set (0.00 sec)

进行复制操作

mysql> create table person_bakup select * from Person;
Query OK, 3 rows affected (0.00 sec)
Records: 3 Duplicates: 0 Warnings: 0

也可以通过查看建表语句,然后复制修改得到新表,然后使用

insert into new_table select * from old_table;

删除语句

删除语句中的条件有些限制比如

DELETE FROM table_name WHERE id in (select A.id from table_name A, table_name B where  A.vala > B.vala and A.valb == B.valb)

如果把valb理解为部门id,把vala理解为工资,那么上述语句在能执行的情况下得到的效果为保留table_name中每个部门里工资最低的那个人得记录。但是真的去执行的话会报错,因为DELETE中的where好像不能直接写和正在删除那个表有关的条件(其实也可以理解,如果一边删一遍条件就会相应的变掉了),但其实我们只要更加没有删前的条件来执行语句,并不会产生这样的情况或者这样的需求。同过嵌套一层select可以达到这个目的:

DELETE FROM table_name WHERE id in (select * from (select A.id from table_name A, table_name B where  A.vala > B.vala and A.valb == B.valb) X)

查询

别名

列别名

列别名可以用在order by, group by 和having子句中,但是不能用在where子句中,比如下面这样的sql会报错

select name as s from students where s = 'tkl'

Unknown column 's' in 'where clause'

列别名一般只是做一个名称统一工作,来返回给应用后台。因为实际列在不同查询中可能是通过不同途径得到的,也可能在不同的表中以不同的列名存在,而后台应用程序的特定程序语言实现的Model一般都是字段名称已经固定的,统一名称可以方便的做ORM。

表别名

表别名使用的比较多,第一它可大大的简化SQL语句,因为处于避免重名和其他的一些命名考虑,表名通常不会太短。第二它可以使得一些原本无法进行的查询得以执行,通常是做表自身连接操作,连接从语义上讲应该是两个表之间进行,如果同一张表进行自连接不采用别名,那么就还是认为只有一个表,从而发生错误。比如有一张成绩表score(id, name, score, class),现在要找出每个class中获得相同分数(只要分数重复了就可以)的那些人。使用别名可以得到如下sql语句

select A.* from score as A, score as B where A.class = B.class and A.score = B.score

这里没有使用显式的连接,在where中使用多个表,相当于是做了一次笛卡尔积,然后再根据条件筛选。

MySQL常用操作汇编的更多相关文章

  1. mysql常用操作语句

    mysql常用操作语句 1.mysql -u root -p   2.mysql -h localhost -u root -p database_name 2.列出数据库: 1.show datab ...

  2. MySQL常用操作总结

    MySQL常用操作 前提条件:已安装MySQL. 学习目标:用一条sql语句写出A和B的剩余数量 AA表 BB表 以上为一道面试题,接下来由这道面试题来回顾一些数据库的基本操作. 登录MySQL su ...

  3. centos LAMP第四部分mysql操作 忘记root密码 skip-innodb 配置慢查询日志 mysql常用操作 mysql常用操作 mysql备份与恢复 第二十二节课

    centos  LAMP第四部分mysql操作  忘记root密码  skip-innodb 配置慢查询日志 mysql常用操作  mysql常用操作 mysql备份与恢复   第二十二节课 mysq ...

  4. Windows平台下MySQL常用操作与命令

    Windows平台下MySQL常用操作与命令 Windows平台下MySQL常用操作与命令,学习mysql的朋友可以参考下. 1.导出整个数据库 mysqldump -u 用户名 -p --defau ...

  5. MySQL常用操作2

    MySQL常用操作2 判断函数 IF(expr, value1, value2)  --  如果表达式expr为true,则返回value1,否则返回value2 IFNULL(value1, val ...

  6. MYSQL常用操作函数的封装

    1.mysql常用函数封装文件:mysql.func.php <?php /** * 连接MYSQL函数 * @param string $host * @param string $usern ...

  7. 第二篇 Mysql常用操作记录(转载)

    我们在创建网站的时候,一般需要用到数据库.考虑到安全性,建议使用非root用户.常用命令如下: 1.新建用户 //登录MYSQL@>mysql -u root -p@>密码//创建用户my ...

  8. Linux 笔记 - 第十五章 MySQL 常用操作和 phpMyAdmin

    博客地址:http://www.moonxy.com 一.前言 前面几章介绍了 MySQL 的安装和简单的配置,只会这些还不够,作为 Linux 系统管理员,我们还需要掌握一些基本的操作,以满足日常管 ...

  9. mysql常用操作及常见问题

    常用操作 mysql备份: --整库备份 docker exec 容器ID mysqldump -uroot -p密码 --databases 库名 > 库名.sql --仅导出表和数据 mys ...

随机推荐

  1. 大脸猫讲逆向之ARM汇编中PC寄存器详解

    i春秋作家:v4ever 近日,在研究一些开源native层hook方案的实现方式,并据此对ARM汇编层中容易出问题的一些地方做了整理,以便后来人能有从中有所收获并应用于现实问题中.当然,文中许多介绍 ...

  2. postgresql-日志表

    pg_log,数据库日志表postgresqllog CREATE TABLE postgres_log ( log_time timestamp(3) with time zone, 日志生成时间 ...

  3. postgresql-tps

    tps TPS就是每秒事务数,但是事务是基于虚拟用户数的,假如1个虚拟用户在1秒内完成1笔事务,那么TPS明显就是1:如果 某笔业务响应时间是1ms,那么1个用户在1秒内能完成1000笔事务,TPS就 ...

  4. POJ 2610

    #include<iostream> #include<iomanip> using namespace std; int main() { //freopen("a ...

  5. 01-01java概述 doc命令、jdk\jre下载安装、path、classpath配置、开发中常见小问题

    1:计算机概述(了解) (1)计算机 (2)计算机硬件 (3)计算机软件 系统软件:window,linux,mac 应用软件:qq,yy,飞秋 (4)软件开发(理解) 软件:是由数据和指令组成的.( ...

  6. [每天解决一问题系列 - 0001] Javascript apply和 call对比

    相同点: 每个函数都包含这两个原生的方法 他们两个的效果是一样的,用于在特定的作用域下执行函数,本质上是设置函数内this对象的值. 不同点: 传入的参数类型不同 . apply(函数作用域,arra ...

  7. Redhat/CentOS 制作本地yum源

    一.制作本地yum源的场景有: (1) 操作系统ISO文件是通过光驱读取的 (2) 操作系统ISO文件是通过USB设备挂载的 (3) 操作系统ISO文件是被上传到本地文件夹的形式 二. 这3种配置方式 ...

  8. SpringBoot用@ConfigurationProperties获取配置文件值

    SpringBoot的配置文件有yml和properties两种,看一些文章说yml以数据为中心,比较好.个人觉得properties更好用,所以这里以properties格式为例来说. 我们都知道@ ...

  9. 《第一本Docker书》

    Docker简介 Docker依赖写时复制(copy-on-write),使修改应用程序非常迅速. Docker推荐单个容器只运行一个应用或进程,鼓励面向服务的架构和微服务架构. Docker的核心组 ...

  10. 如何恢复windows的exe文件的默认打开方式

    事情由来: 有一次在用一个播放器选择打开视频文件的时候,意外的手贱点击打来了 exe 文件,之后戏剧性的恶心开始了,首先当然是打开失败,接着整个桌面的 exe 文件全部被替换成那个播放器的图标,然后所 ...