MySQL常用操作汇编
熟悉
我熟悉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常用操作汇编的更多相关文章
- mysql常用操作语句
mysql常用操作语句 1.mysql -u root -p 2.mysql -h localhost -u root -p database_name 2.列出数据库: 1.show datab ...
- MySQL常用操作总结
MySQL常用操作 前提条件:已安装MySQL. 学习目标:用一条sql语句写出A和B的剩余数量 AA表 BB表 以上为一道面试题,接下来由这道面试题来回顾一些数据库的基本操作. 登录MySQL su ...
- centos LAMP第四部分mysql操作 忘记root密码 skip-innodb 配置慢查询日志 mysql常用操作 mysql常用操作 mysql备份与恢复 第二十二节课
centos LAMP第四部分mysql操作 忘记root密码 skip-innodb 配置慢查询日志 mysql常用操作 mysql常用操作 mysql备份与恢复 第二十二节课 mysq ...
- Windows平台下MySQL常用操作与命令
Windows平台下MySQL常用操作与命令 Windows平台下MySQL常用操作与命令,学习mysql的朋友可以参考下. 1.导出整个数据库 mysqldump -u 用户名 -p --defau ...
- MySQL常用操作2
MySQL常用操作2 判断函数 IF(expr, value1, value2) -- 如果表达式expr为true,则返回value1,否则返回value2 IFNULL(value1, val ...
- MYSQL常用操作函数的封装
1.mysql常用函数封装文件:mysql.func.php <?php /** * 连接MYSQL函数 * @param string $host * @param string $usern ...
- 第二篇 Mysql常用操作记录(转载)
我们在创建网站的时候,一般需要用到数据库.考虑到安全性,建议使用非root用户.常用命令如下: 1.新建用户 //登录MYSQL@>mysql -u root -p@>密码//创建用户my ...
- Linux 笔记 - 第十五章 MySQL 常用操作和 phpMyAdmin
博客地址:http://www.moonxy.com 一.前言 前面几章介绍了 MySQL 的安装和简单的配置,只会这些还不够,作为 Linux 系统管理员,我们还需要掌握一些基本的操作,以满足日常管 ...
- mysql常用操作及常见问题
常用操作 mysql备份: --整库备份 docker exec 容器ID mysqldump -uroot -p密码 --databases 库名 > 库名.sql --仅导出表和数据 mys ...
随机推荐
- 上传本地文件到github(码云)上(小乌龟方式,sourcetree方式)
一:上传文件到 github 1.打开 https://github.com/ 登录github账号(没有的自己创建),点击右上角创建新仓库 在打开的页面中填写 名字 点击 Create repos ...
- Spring常用知识点
说一下spring中Bean的作用域 singleton: Spring IoC容器中只会存在一个共享的Bean实例,无论有多少个Bean引用它,始终指向同一对象.Singleton作用域是Sprin ...
- python批量拷贝文件
普通批量拷贝文件 import os import shutil import logging from logging import handlers from colorama import Fo ...
- Vue2.5开发去哪儿网App 第三章笔记 上
1. vue 生命周期函数 每个 Vue 实例在被创建之前都要经过一系列的初始化过程.例如,实例需要配置数据观测(data observer).编译模版.挂载实例到 DOM ,然后在数据变化时更新 ...
- BIND DNS拒绝服务漏洞 CVE-2016-2776修复
接到此漏洞之后,略微查了一下相关描述,发现漏洞影响范围很大,可能造成的影响也很严重,于是着手进行修复. 漏洞的详细信息可见如下链接: http://www.cnvd.org.cn/flaw/show/ ...
- python 相关模块安装 国内镜像地址
python 相关模块安装 国内镜像地址 pipy国内镜像目前有: http://pypi.douban.com/ 豆瓣 http://pypi.hustunique.com/ 华中理工大学 ht ...
- 多线程的实现及常用方法_DAY23
1:多线程(理解) (1)如果一个应用程序有多条执行路径,则被称为多线程程序. 进程:正在执行的程序. 线程:程序的执行路径,执行单元. 单线程:如果一个应用程序只有一条执行路径,则被称为单线程程序. ...
- Java8简明指南
Java8简明指南 转载自并发编程网 – ifeve.com本文链接地址: Java8简明指南 欢迎来到Java8简明指南.本教程将一步一步指导你通过所有新语言特性.由短而简单的代码示例,带你了解如何 ...
- Shell 常用的命令
ls功能:列出目录内容常用选项:-a 显示所有文件,包括隐藏的-l 长格式列出信息-i 显示文件 inode 号-t 按修改时间排序-r 按修改时间倒序排序-h 打印易读大小单位 2 echo功能:打 ...
- Choose GitLab for your next open source project
原文:https://b.agilob.net/choose-gitlab-for-your-next-project/ GitLab.com is a competitor of GIthub. I ...