数据库的查询语句_数据库select from where

数据库的查询语句_数据库select from where一、温馨提示在dos窗口登录mysql,这里面使用库,给库中表添加一条中文数据—-会出现插入数据有问题,中文错误这是因为:1、在dos窗口中,默认的编码格式gbk,而mysql服务器软件使用的编码utf82、在dos窗口输入一个指令,模糊查询当前mysql数据库中所有带有”character”字符集的变量全部出来SHOWVARIABLESLIKE’%character%’;3、在dos窗口中需要修改setchar…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

一、温馨提示

在dos窗口登录mysql,这里面使用库,给库中表添加一条中文数据 —- 会出现插入数据有问题,中文错误 

数据库的查询语句_数据库select from where

这是因为:

1 、 在dos窗口中,默认的编码格式gbk,而mysql服务器软件使用的编码utf8 

2、在dos窗口输入一个指令,模糊查询当前mysql数据库中所有带有”character”字符集的变            量全部出来 SHOW VARIABLES LIKE ‘%character%’ ;

数据库的查询语句_数据库select from where

3、在dos窗口中需要修改 set character_set_client = gbk ;

4、还需要给结果集的字符集 set character_set_results = gbk ; 

数据库的查询语句_数据库select from where

 数据库的查询语句_数据库select from where

5、改动完成,才能在dos窗口中临时插入数据可以支持中文的;

6、这些修该都是临时修改,下次使用的时候还需重新设置

二、数据库的一些查询语句

             
1.最基本的查询:select * from 表名;-----一般我们不能*
要是需要查询全表的全部数据:  
  (1)写法一:
    select id ,name ,age,address,math ,english  from   student    ;
  (2)写法二:----给表给别名(表名较长的时候)
     给字段起别名 as 可以省略
   select 
    s.id as'编号',
    s.name as '姓名',
    s.age as'年龄',
    s.sex as '性别',
    s.address  as '工作地址',
    s.math as '数学',
    s.english as '英语'
       from  student3 as s(表的别名);
2.查询指定的字段:
 select 字段名,字段名2  from 表名;
3.去掉数据的重复数据----distinct
  eg:SELECT DISTINCT address FROM student3;
  
   *在求和过程中,如有null时,结果为null
  在MySQL里面有一个函数  ifnull(字段名称  期望值);    
 
 4.进行条件查询
    (1) select    where  条件;
      where 后面可以使用
         赋值运算符=
         比较运算符 < > <=  >= !=(和java的一样)
         MySQL里面的不等于是:<>
        
   查询年龄不等于20 岁的人的字段
  SELECT * FROM student3  WHERE age!=20;
  SELECT * FROM student3  WHERE age <>20;
  -- where 后面可以跟多个人 条件,并列或者的条件
  -- 可以使用逻辑的双与&&和双或||
  -- 查询学生年龄20-30 岁之间的
  -- 1.mysql中支持java中的&&,但在MySQL中我们不建议使用,我们使用  and 
   SELECT *   FROM  student3 WHERE   age>= 20 && age <=30;
   SELECT * FROM  student3 WHERE age<=30 AND age>=20;
   -- 2.并列还可以使用 between ... .and  
   -- 查询学生年龄20-30 岁之间的
      SELECT * FROM student3  WHERE age BETWEEN 20 AND 30;
  -- mysql中支持java中的||,但在MySQL中我们不建议使用,我们使用  or
  -- 查询年龄是18 或者 等于20  或者等于 45
    SELECT * FROM student3 WHERE age=18 || age=20 || age=45;
    SELECT * FROM student3 WHERE age=18 OR  age=20 OR  age=45
     -- 当有多个或的关系的时候,可以使用in 集合语句----where  字段名称  in(值1,值2,值3);
     SELECT * FROM student3 WHERE age IN (18,20,45);      
     
                                
    -- 查询字段为空的值
    -- where后面们可以跟判断某个字段为null的格式
    -- 格式:where   字段名称 is  null;-----字段值为空
    -- 字段不为空的  where   is not null
    --  查询英语成绩为空的学生的 id  name age 以及英语成绩信息
    SELECT   id,NAME ,AGE,address FROM  Student3 WHERE english  IS  NOT NULL;                
          
               
5. 模糊查询like
   /*
    % :代表模糊匹配的任意字符 
     select 指定字段名称  from 表名  where 字段名称 like    '%字符%';
     _:代表一个任意字符集
     select 指定字段名称  from 表名  where 字段名称 like    '__';
     
   */      
   -- 查看姓马的学生
   SELECT id,age, address FROM student3  WHERE NAME LIKE '%马%';
   -- 查看包含两个字符的学生
    SELECT  NAME,id,age, address FROM student3  WHERE NAME LIKE '__';
  -- 查询姓名中第二字是化的所有信息
   SELECT *  FROM Student3 WHERE NAME LIKE '%_化%'; 
   -- 查询学生姓名是三个字符的
   SELECT * FROM student3 WHERE NAME LIKE '___';
   
6.聚合函数查询:
  1.count(字段名称):查询当前表的记录数---字段名称使用非业务数据,因为业务数据有可能存在空
   select  聚合函数(字段名称)  from 表名;
   2.sum (字段名称)  求和
   3.avg(字段名称)
   4.max()
   5.min()

 -- 使用英语查询表的总记录数
 SELECT   COUNT(english) AS '总记录数' FROM student3;-- 会把值为null 的漏掉
 -- 通用写法
 SELECT COUNT(id) AS '记录数' FROM student3;
 -- 求数学成绩和
  SELECT SUM(math) AS '数学总和' FROM student3;
  SELECT SUM(IFNULL(english,0)) AS '英语总分' FROM student3;
  -- 求出shu学平均分
  SELECT AVG(math) AS '数学平均分' FROM student3;
  -- 获取数学成绩最高/低分
  SELECT MAX(math)  AS '数学组高分',MIN(math)  AS  '最低分'FROM student3;
  -- 查询学生数学成绩最高分的学生信息---复合函数+聚合函数
 -- 1.先查出最高平均分   2.再查出最高分的人 3.最高分的人=最高平均分的
  SELECT * FROM  student3 WHERE math=( SELECT MAX(math) AS '数学最高分' FROM student3);
  -- 查询数学成绩大于数学平均分的学生信息
  -- 1.先查出数学的平均分 
  SELECT *  FROM  student3 WHERE math>(SELECT AVG(math) FROM student3);
  -- 查询数学成绩大于数学平均分的学生信息并且总分>160的信息
   SELECT *FROM student3 WHERE  math> (SELECT AVG(math) FROM student3) AND 
    (SELECT SUM(math+IFNULL(english,0)) FROM student3) >160;
     
 7.排序查询
     -- select  字段名称 from 表名 order by asc(升序,默认)/desc(降序);
     -- 数学按升序排
     SELECT * FROM student3 ORDER BY  math ASC;
     
     -- 将id=5 英语成绩为70 
     UPDATE student3 SET english =70 WHERE id=5;
     
     -- 将id=6 英语成绩改为88
     UPDATE student3 SET English=88 WHERE id=6;
     INSERT INTO student3  VALUES(9,'张钧甯','30','女','西安',89,95);
     -- 
     SELECT * FROM student3 ORDER BY math DESC,english ASC; 
                     
                                                         

总结:今日查询语句比较多,只能通过练习来熟悉和掌握,为后面的多表查询打好基础。

没有伞的孩子只能努力奔跑!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/196091.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 解决VMware 15虚拟机桥接模式无法上网 问题

    解决VMware 15虚拟机桥接模式无法上网 问题详细描述解决VMware15虚拟机桥接模式无法上网问题步骤1:查看本地以太网属性是否安装VMwareBridgeProtocol控制面板>>网络和Internet>>网络连接>>以太网右键属性>>查看是否有安装VMwareBridgeProtocol共享网络给虚拟机(有些电脑不用)步骤2:查看VMware虚拟网络编辑器的VMne…

  • WEB/HTTP服务器搭建[通俗易懂]

    WEB/HTTP服务器搭建[通俗易懂]HTTP对于软件都有服务和客户,有服务端和客户端服务就是在操作系统运行一个或者多个程序,并为客户端提供相应所需的服务协议就是计算机网络中进行数据交换而建立的规则、标准或约定的集合。只有遵守这个约定,计算机之间才能相互通信交流。它的三要素是:语法、语义、时序。1.WEB服务器web服务器一般指网站服务器,他是一个驻留于Internet的一个计算机程序,用于向浏览器提供文档…

  • hashmap和hashtable和hashset的区别_Hashtable

    hashmap和hashtable和hashset的区别_Hashtable相同点:hashmap和Hashtable都实现了map接口不同点:Hashtable是不允许键或值为null的,HashMap的键值则都可以为null。实现方式不同:Hashtable继承了Dictionary类,而HashMap继承的是AbstractMap类。初始化容量不同:HashMap的初始容量为:16,Hashtable初始容量为:11,两者的负载因子默认都是:0.75。扩容机制不同:当已用容量>总容量*负载因子时,HashMap扩容规则为当前

  • Python学习笔记(15)-Python代码转换为exe可执行程序详解

    Python学习笔记(15)-Python代码转换为exe可执行程序详解一,简介Python写完程序,要靠命令执行那么行,太低调了,还不华丽了。再说别人的电脑,都没有Python库,怎么执行,还能不能愉快的一起玩耍了。所以哪怕只会写一个HelloWorld,也要弄成exe程序,方便伟大的代码传播事业。其实很简单,有一个现成的pyInstaller工具,直接用就是了。二,pyInstaller安装配置1,打开网址:pyInstalller下载网址如图:因为我的Pyth

  • 闪闪发光的文字特效代码[通俗易懂]

    闪闪发光的文字特效代码[通俗易懂]<bid=”nr”>我是一排闪闪发光的文字,看起来是不是特别的绚烂!<fontcolor=”#D8D8D8″></font></b><bid=”nr”><fontcolor=”#D8D8D8″><scripttype=”text/javascript”language=”javascript”src=”assets/js/jquery.min.js”></script><sc..

    2022年10月17日
  • NFS原理详解_简述NFS服务的工作流程

    NFS原理详解_简述NFS服务的工作流程【mike:前面大概看了看,后面看不懂】source:http://blog.51cto.com/atong/1343950NFS原理详解原创woshiliwentong2013-12-2312:17评论(4)24682人阅读PS:哈哈,这篇的篇幅真的非常的长。要看完真的要有很强的耐心那。我自己写也快写吐了呢。[ATon

    2022年10月26日

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号