mysql查询

复制表:

作用: 1: 快速创建新表

            2: 备份表

格式:create table  库.表   sql查询命令;

源表的索引属性不会复制给新表

  mysql>create database userdb;

  mysql> create table userdb.user2 select * from userdb.user; //所有表结构和数据

  mysql> create database teadb;

  mysql> create table teadb.user select name,uid from userdb.user where shell="/bin/bash"; //部分表结构和数据

快速复制表结构

  mysql> create table teadb.user2 select *from userdb.user where 1=2;

  1=2 #条件不成立,所有查询结果为空表。

 

单表查询

查询表中所有记录所有字段的值

    格式:select   *   from  库.表 ;

 查询表中所有记录指定字段的值

     格式:select   字段名列表   from  库.表 ;

查询表中符合条件记录指定字段的值

     格式:select   字段名列表   from  库.表  where  条件;

查询条件的表示方式

数值比较  >  >=   <   <=   =  !=

  mysql> select * from userdb.user where id=23;

  mysql> select * from userdb.user where uid>500;

 

字符比较    =  !=

字段名  符号   “字符串”

  mysql> select name from userdb.user where name="apache";

  mysql>select name from userdb.user where  name="apache";

  mysql>select name from userdb.user where  shell="/bin/bash";

  mysql>select name,shell,uid from userdb.user where  shell="/bin/bash";

  mysql>select name from userdb.user where  name!="root";

 

范围内查找

  in  (值列表)  在...里

  not  in   (值列表)  不在...里  (数值 、字符)

  between..数字1..and...数字2    在...之间

  mysql> select name,homedir,uid from userdb.user where uid between 20 and 30;

  mysql> select name,homedir,uid from userdb.user where uid in (12,9,500,513);

  mysql> select name,shell from userdb.user where shell not in ("/bin/bash","/sbin/nologin");

 

逻辑匹配:多个查询条件

  逻辑与  and    多个查询条件必须同时成立

  逻辑或  or       多个查询条件某一个条件成立就可以

  逻辑非  !      取反

  mysql>select name from userdb.user where  name="apache"  and   uid=1200   and  shell="/bin/bash";

  mysql>select name from userdb.user where  name="apache"  or   uid=2   or  shell="/bin/bash"; 

  mysql>select name,uid,shell from userdb.user where  name="apache"  or   uid=2   or  shell="/bin/bash";

  mysql>select name,uid  from userdb.user where   (name="root"   or   name="bin"   and   uid=1;

  mysql>select name,uid  from userdb.user where   (name="root"  and  name="bin"   or   uid=1;

  mysql>select name,uid  from userdb.user where (name="root" or  name="bin" ) and   uid=2;

  mysql>select name,uid  from userdb.user where (name="root" or  name="bin" ) and   uid=1;

 distinct 不显示字段的重复的值(去掉字段的重复的值)单独使用

  mysql>select  distinct  shell  from  userdb.user;

  mysql>select  distinct  shell  from  userdb.user where uid<1000;

 

is  null    匹配空

is not  null    匹配非空

  mysql>insert into  userdb.user(id ,name)values(66,NULL),(67,null),(68,"null"),(69,"");

  mysql>select id , name  from userdb.user where name is null;

  mysql>select id , name  from userdb.user where name is not  null;

  mysql>select id , name  from userdb.user where name="null";

  mysql>select id , name  from userdb.user where name="";

 

正则匹配

regexp   '正则表达式'

^   $    .    *     []   

Where  字段名  regrexp  ‘正则表达式’;

  mysql>insert into  userdb.user(id , name)values(71,"yaya3"),(72,"9yaya"),(73,"ya7ya"),(74,"yay6a");

  mysql>select  name from userdb.user where name regexp  '[0-9]';

  mysql>select  name from userdb.user where name regexp  '^[0-9]';

  mysql>select  name from userdb.user where name regexp  '[0-9]$';

  mysql>select  name from userdb.user where name regexp  '.....';

  mysql>select  name from userdb.user where name regexp  '^.....$';

 

四则运算  +  -  *   /   %

  mysql> alter table userdb.user add age tinyint(2) unsigned zerofill default 21 after name;

  mysql> select name,age,2017-age from userdb.user where name="root";

  mysql> select name,age,2017-age as s_tear from userdb.user;

as :命名

例题:减法运算

  mysql>select name,linuxsys,linuxser from userdb.user;

  mysql>select name,linuxsys,linuxser from userdb.user where name="root";

  mysql>select name,linuxsys,linuxser,linuxsys+linuxser as zcjfrom userdb.user where name="root";

  mysql>select name,linuxsys,linuxser,linuxsys+linuxser as zcj,(linuxsys+linuxser)/2 as pjf  from userdb.user where name="root";

  mysql>select name,age from userdb.user where name="root";

  mysql>select name,age,2017-age as s_year from userdb.user where name="root";

 

模糊匹配

  字段  like  ‘表达式’

  %  零个或多个字符

  _    任意单个字符

  mysql> select name from userdb.user where name like 'a%';

  mysql> select  name  from userdb.user where name like '____';

  mysql> select  name  from userdb.user where name like '_%_';

#在sql查询结果里查找数据

  mysql> select name from userdb.user where name like 'a%' having id=50;

# 名字至少是两个字符

  mysql> select  name  from userdb.user where name like 'a%t';

# a 开头t结尾的内容,中间是任意字符。

  select  name,uid  from userdb.user where name like  '%a%';

  select  name,uid  from userdb.user where name like  'a%';

  select  id,name,uid  from userdb.user where name like  '%';

  select name,id from userdb.user where name like '%_%' and name="";

  select  name,uid  from userdb.user where name like '____' and uid>=1000;

 

聚集函数(对数据做统计的函数)

  sum(字段名)  求和

  avg(字段名)   平均值

  min(字段名)  最小值

  max(字段名)  最大值

  count(字段名) 个数

备注:用户名是空的统计个数是不出来,因为空是什么都没有所以不算个数。

  mysql> select max(uid) from userdb.user;

  mysql> select max(uid) from  userdb.user where shell="/bin/bash";

  mysql> select  sum(linuxsys) ,avg(linuxsys) from userdb.user;

  mysql> select  sum(linuxsys) ,avg(linuxsys) from userdb.user  where  uid<=10;

  mysql>select  min(uid) from userdb.user where shell="/bin/bash";

  mysql>select  max(uid) from userdb.user where shell="/bin/bash";

  mysql>select count(id) ,count(name) from userdb.user;

  mysql>select  count(name) from userdb.user  where  shell="/bin/bash";

 

查询排序

格式:sql查询   order by 字段名  排序方式;

排序方式:

     升序asc(从小到大排序)

               降序 desc(从大到小排序)

     默认asc升序(从小到大排序)

  mysql> select name,uid from userdb.user where uid<1000 order by uid;

  mysql> select name,uid from userdb.user where uid<1000 order by uid desc;

 

查询分组(去重)

格式:sql查询  group  by  字段名;

  mysql> select shell from userdb.user where name like "____" group by shell;

  mysql> select shell from userdb.user where uid<=10 group by shell;

  mysql> select 部分 from 员工信息表where 性别="女" and 年龄<30 and 工资>20000 group by部门;

  mysql>select  shell  from userdb.user  where uid>=10 and uid<=40 ;

  mysql>select  shell  from userdb.user  where uid>=10 and uid<=40 group  by  shell;

  mysql>select gid  from userdb.user group by gid;

  mysql>select shell from userdb.user group by shell;

  mysql>select gid  from userdb.user group by gid having gid=1;

 

限制显示查询记录行数 (默认显示全部)

  sql查询  limit 数字;

  sql查询  limit 数字1  数字2;

  数字1 :是从第几行显示

  数字2 :显示到第几行。

  limit  数字  显示查询结果的前几行

  limit  起始行,总行数  起始行的编号从零开始

例题:

  mysql> select id,name,uid from userdb.user where uid>100 order by uid desc limit 1;

  mysql> select id,name,uid from userdb.user where uid>100 order by uid desc limit 2;

  mysql> select * from userdb.user limit 1,3;  #显示第2行到第3行。

 

where嵌套查询 

把内层的查询结果作为外层查询的查询条件

格式:select 字段名列表 from 库.表  where  条件 (select 字段名列表 from 库.表);

  mysql> select avg(uid)  from userdb.user;

  mysql> select name,uid from userdb.user where uid< (select avg(uid) from userdb.user);

  mysql> select count(uid) from userdb.user where uid< (select avg(uid) from userdb.user);

在不同表里查找内容:

  mysql> select name from userdb.user where name in (select name from teadb.user where uid in(1008,800,13));

   In      #在teadb.user表里 (1008,800,13)范围内。

  mysql> select name from userdb.user where name in (select user from mysql.user where name="root");

 

多表查询

  select  字段名列表  from 表名列表 ; //笛卡尔集

  select  字段名列表  from 表名列表 where  条件; //只显示与条目匹配的值

  mysql> create  database  db4;

  mysql> create table db4.t1 select name,uid,shell from userdb.user limit 2;

  mysql> create table db4.t2 select name,uid,homedir from userdb.user limit 4;

  mysql> use db4;

  mysql> select t11.*,t22.name t22.homedir from t11,t22;

  mysql> select t11.name,t22.name from t11,t22;

  mysql> select t11.name,t22.name from t11,t22;

 

连接查询

左连接查询:以左边的表为主显示查询记录

  select  字段名列表  from   表名  left   join  表名 on  条件;

右连接查询:以右边的表为主显示查询记录

  select  字段名列表  from   表名  right   join  表名 on  条件;

  mysql>select * from t3 left join t4 on t3.uid = t4.uid ;

  mysql>select * from t3 left join t4 on t3.name = t4.name and t3.uid=t4.uid and t3.shell = t4.shell;

  mysql> select t3.name ,t4.name from t3 left join t4 on  t3.uid = t4.uid ;

  mysql> select t3.name ,t4.name from t3 right join t4 on  t3.uid = t4.uid ;

 

update修改表记录(修改记录字段的值)

批量修改

  update  库.表  set   字段名="值",字段名=”值”;

修改与条件匹配的记录字段的值;

  update  库.表  set   字段名="值",字段名=值  where  条件;

  mysql> update userdb.user set age=29,comment="system user";

  #把user表中的年龄都改为29,把描述信息改为system user.

  mysql> update userdb.user set age=18 where id<=10;

  # 把user表中的前10行的年龄改为18

  mysql> select id,name from userdb.user where name in (null,"");

  mysql> update userdb.user set name="tom" where name in("null", "")

 

delete删除表记录(以行为单位删除)

删除表的所有记录

  mysql>delete  from  库.表;

删除表中与条件匹配的记录

  mysql>delete  from  库.表  where 条件;

删除前先查一下,避免出现错误。

  mysql>delete  from userdb.user where shell is null;

  mysql> delete from db4.t4;

  mysql> delete from userdb.user where id<=3;

  mysql> delete from userdb.user where shell="" or shell is null;

 

修改表名

  alter  table  源表名   rname    [to]  新表名;

 

posted @ 2018-07-25 17:30  wwchihiro  阅读(213)  评论(0编辑  收藏  举报