---恢复内容开始---

登录

>mysql -uroot -p1234

mysql登录 -u+用户 -p 密码

显示数据库

show databases;

使用某个数据库

use xxx;

显示数据库表

show tables

显示表结构

show columns form xxx;//表名

select选择

使用distinct来输出MYsql只返回不同的值

select distinct email from user//必须放在这个字段的前面

部分不能使用这个关键字(这个关键字用于可以用于所有列)除非指定的两个列都不同,否则所有的行都被检索出来

limit限制结果


  select id from user limit 5,10

第一个参数为下标从几个开始,从下标为0开始

第二个参数为要检索的行数

排序:(asc 正序 desc 逆序)

select id from user order by id limit 0,10

必须先进行排序后进行限制结果不然会报错的

is null和=null的区别

按照ANSI SQL标准,下面的两个查询都不返回任何行:

查询一: SELECT * FROM test WHERE data=NULL

查询二: SELECT * FROM test WHERE data<>NULL

详细:http://blog.csdn.net/freshlover/article/details/8973266

where中的not关键字很有用在复杂的语句中

  select * from user where id not in(12,13); 

Like的通配符的进行过滤

select * from user where name LIKE 'a%';

注意在这里面的字符是区分大小写的,%代表可以出任意次数。

select * from user where name LIKE 'a_';

_代表一个字符匹配!

mysql 使用concat来对字符进行连接

select concat(id,'(',name,')') from t_user;

mysql 中如果使用时间作为查询条件的话,最好使用Date()函数来修饰这个时间字段

select * from t_user where Date(someTime)='2016-01-01';

因为如果你的数据库的时间是timeStamp类型的话带有时分秒会导致其检索失败;

group By分组查询

 select count(id) as c,position as  p  from t_user group by position having c >10;

相关组查询中having组查询中的筛选条件,

select 的顺序

  From 检索的表

  where 查询条件(行级过滤)

  group BY 分组说明

  having 组级过滤

  order by 输出排序的顺序

  Limit 要检索的行数

利用where语句进行多表查询

select m.sendto,u.name from t_mail as m,t_user as u where m.senderid=u.id group by u.id;

利用内联

---恢复内容结束---

登录

>mysql -uroot -p1234

mysql登录 -u+用户 -p 密码

显示数据库

show databases;

使用某个数据库

use xxx;

显示数据库表

show tables

显示表结构

show columns form xxx;//表名

select选择

使用distinct来输出MYsql只返回不同的值

select distinct email from user//必须放在这个字段的前面

部分不能使用这个关键字(这个关键字用于可以用于所有列)除非指定的两个列都不同,否则所有的行都被检索出来

limit限制结果


  select id from user limit 5,10

第一个参数为下标从几个开始,从下标为0开始

第二个参数为要检索的行数

排序:(asc 正序 desc 逆序)

select id from user order by id limit 0,10

必须先进行排序后进行限制结果不然会报错的

is null和=null的区别

按照ANSI SQL标准,下面的两个查询都不返回任何行:

查询一: SELECT * FROM test WHERE data=NULL

查询二: SELECT * FROM test WHERE data<>NULL

详细:http://blog.csdn.net/freshlover/article/details/8973266

where中的not关键字很有用在复杂的语句中

  select * from user where id not in(12,13); 

Like的通配符的进行过滤

select * from user where name LIKE 'a%';

注意在这里面的字符是区分大小写的,%代表可以出任意次数。

select * from user where name LIKE 'a_';

_代表一个字符匹配!

mysql 使用concat来对字符进行连接

select concat(id,'(',name,')') from t_user;

mysql 中如果使用时间作为查询条件的话,最好使用Date()函数来修饰这个时间字段

select * from t_user where Date(someTime)='2016-01-01';

因为如果你的数据库的时间是timeStamp类型的话带有时分秒会导致其检索失败;

group By分组查询

 select count(id) as c,position as  p  from t_user group by position having c >10;

相关组查询中having组查询中的筛选条件,

select 的顺序

  From 检索的表

  where 查询条件(行级过滤)

  group BY 分组说明

  having 组级过滤

  order by 输出排序的顺序

  Limit 要检索的行数

利用where语句进行多表查询

select m.sendto,u.name from t_mail as m,t_user as u where m.senderid=u.id group by u.id;

利用内联 使用inner join on进行内联

 select m.sendto,u.name from t_mail as m Inner join t_user as u on  m.senderid=u.id group by u.id;

外联 查找那些和他没相关的信息也就是另一张表为空

左外联

 select m.sendto,u.name from t_mail as m left outer join t_user as u on  m.senderid=u.id group by u.id;

右外联

 select m.sendto,u.name from t_mail as m right outer join t_user as u on  m.senderid=u.id group by u.id;

这两种的外连接的区别的是left是以左边的表为主列出他的所有的行,与右边的表进行匹配

内联和外联的区别是

是不是将没有关联的字段加入

插入数据

insert into user values(1,'a');//需要插入该表的所有的字段的数据

不推荐 使用上面的用法

最好是使用指定列名

 insert into user(id,name) values(1,'a');//指定列名可以保证数据表结构改变了也可以正常运行

多条数据插入(用,分隔)

 insert into user(id,name) values(1,100),(2,300);

插入检索出来的数据

insert into user(id,name) select id ,name from user

创建一个表

 CREATE TABLE info(
id int not null primary key AUTO_INCREMENT,
content char(50)
)

删除表

drop table user;

重命名

rename table info to info2;

事务

start TRANSACTION//开启事务
insert into info2(id ,name) values(1,'');
commit;//提交

mysql那些事的更多相关文章

  1. mysql那些事之索引篇

    mysql那些事之索引篇 上一篇博客已经简单从广的方面介绍了一下mysql整体架构以及物理结构的内容. 本篇博客的内容是mysql的索引,索引无论是在面试还是我们日常工作中都是非常的重要一环. 索引是 ...

  2. mysql那些事(6) WHERE条件 字符串的引号

    前言:所谓的坑,两个意思,一个是软件本身的bug,一个是使用者常犯的错误. phper在日常开发中经常和mysql打交道.特别是在没有分层的中小应用中,phper开发要关注sql语句的实现. 入正题, ...

  3. mysql那些事(5)建表存储引擎的选择

    在mysql见表的时候,会遇到选择存储引擎:MyISAM和InnoDB.究竟用哪种存储引擎好呢? 1.MyISAM:表锁:支持全文索引:读并发性能较好. 2.InnoDB:行锁:支持事务,支持外键:写 ...

  4. mysql那些事(4)建库建表编码的选择

    mysql建数据库或者建表的时候会遇到选择编码的问题,以前我们都是习惯性的选择utf8,但是在mysql在5.5.3版本后加了utf8mb4的编码,utf8mb4可以存4个字节Unicode,mb4就 ...

  5. mysql那些事(3)小数如何存储

    创建mysql数据表的时候,经常会遇到存储小数(浮点数)的情况,如:价格,重量,身高等. 目前大的公司流行三种存储方案: 1.将数据扩大10的倍数达到使用整数类型存储目的. 比如价格,我们经常以分为单 ...

  6. mysql那些事(2)时间类型数据如何存储

    几乎每次数据库建模的时候,都会遇到时间类型数据存储的问题. mysql存储时间通常选择这四种类型:datetime.timestamp.int和bigint四种方式,到底使用什么类型,需要看具体的业务 ...

  7. mysql那些事(1)手机号与座机号码如何存储

    创建mysql数据表的时候,经常会遇到手机号码和座机号码数据的存储问题. 先说手机号码:很多人喜欢使用数字来进行存储,手机号不涉及到运算,并且有时候要带括号,加号之类的字符,有时候还要以0开头.所以, ...

  8. MYSQL 那些事

    1.一条update语句 1.先通过引擎找到对应的行数据,并加锁 2.对行数据进行修改并调用引擎接口修改这条数据,然后释放锁(此时并没有把数据在磁盘上做出修改) 3.redo log在内存中生成这条u ...

  9. PHP基础之与MySQL那些事

    前言 这篇文章会对PHP的MySQL扩展库,MySQLI的扩展库,SQL批量执行,事务控制等等进行一些简单的讲解. MySQL扩展 PHP中MySQL扩展,虽然因为安全的原因,在PHP5.6及往上不在 ...

随机推荐

  1. python操作mysql,增,删,改,查

    import MySQLdb conn = MySQLdb.connect(host='192.168.1.21',user='yangqw',passwd='1',db='free')cur = c ...

  2. 【转】CString,string,char*综合比较

    (一)  概述 1.string和CString均是字符串模a板类: 2.string为标准模板类(STL)定义的字符串类,已经纳入C++标准之中: 3.CString(typedef CString ...

  3. TCP那些事儿(下)

    这篇文章是下篇,所以如果你对TCP不熟悉的话,还请你先看看上篇<TCP的那些事儿(上)> 上篇中,我们介绍了TCP的协议头.状态机.数据重传中的东西.但是TCP要解决一个很大的事,那就是要 ...

  4. squid安装及运行指南

    squid安装及运行指南 0. What is squid Squid是一个高性能的代理缓存服务器,Squid支持FTP.gopher.HTTPS和HTTP协议.和一般的代理缓存软件不同,Squid用 ...

  5. jupyter扩展插件Nbextensions使用

    本节主要解释jupyter中各种插件 原创文章,转载请务必注明原作者出处:http://www.cnblogs.com/cloud-ken/p/7401534.html Exercise Exerci ...

  6. python3操作redis

    redis也被称为缓存 1.redis是一个key-value存储系统,没有ForeignKey和ManyToMany的字段. 2.在redis中创建的数据彼此之间是没有关系的,所以也被称为是非关系型 ...

  7. 【OCR技术系列之三】大批量生成文字训练集

    放假了,终于可以继续可以静下心写一写OCR方面的东西.上次谈到文字的切割,今天打算总结一下我们怎么得到用于训练的文字数据集.如果是想训练一个手写体识别的模型,用一些前人收集好的手写文字集就好了,比如中 ...

  8. SSD trim及4k对齐

    trim可以帮助减小SSD的写放大WA问题,删除文件后不仅仅是将文件标记为删除,而是在SSD空闲的时候统一进行删除. Linux下的trim支持叫discard,修改fstab文件,在挂载参数中加上d ...

  9. SSD写入放大问题[转]

    原文地址:http://blog.csdn.net/cywosp/article/details/29812433 之前在SSD(Solid State Drive)上设计并实现缓存系统用于存储数据块 ...

  10. Hadoop RPC简单例子

    jdk中已经提供了一个RPC框架-RMI,但是该PRC框架过于重量级并且可控之处比较少,所以Hadoop RPC实现了自定义的PRC框架. 同其他RPC框架一样,Hadoop RPC分为四个部分: ( ...