• 2022-08-18 第六小组 瞒春 学习笔记


    🚩前言

    🌻今天进行mysql常用函数以及jdbc的学习

    作者简介:大家好我是烫嘴的辛拉面,大家可以叫我拉面。
    个人主页: weixin_49405762的博客
    系列专栏: 经典算法习题集
    为大家推荐一款刷题神器哦 点击跳转进入网站

    ✏️ MySQL常用函数

    ✒️聚合函数

    • count:计数。count(*)≈count(1)>count(主键)
      • count(*):MySQL对count(*)底层优化,count(0)。
      • count(1)
      • count(主键)
      • count(字段)
    • min:最小值
    • max:最大值
    • sum:求和
    • avg:平均值

    ✒️数值型函数

    主要是对数值型进行处理。

    • ceiling(x):向上取整
    • floor(x):向下取整
    • round(x):四舍五入
    • truncate(x,y):返回数字x截断为y位小数的结果
    • PI:圆周率,π
    • rand:返回0到1的随机数
    • abs:绝对值
    -- 绝对值
    select ABS(-4) 4的绝对值,ABS(-1.1);
    -- 向下取整,向上取整,四舍五入
    select CEILING(4.1),FLOOR(1.1),ROUND(-4.4)
    -- 取余
    select MOD(60,11);
    -- 随机数
    select RAND(),RAND(),RAND()
    -- 截断
    select TRUNCATE(2.33999999,2);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    ✒️字符串型函数

    对字符串进行处理。

    • length(s):字符串的长度
    • concat(s1,s2,…sn):合并字符串
    • lower(str):将字母转成小写
    • upper(str):将字母转成大写
    • left(str,x):返回字符串str的左边的x个字符
    • right(str,x):返回字符串str右边的x个字符
    • trim:去掉左右两边的空格
    • replace:替换
    • substring:截取
    • reverse:反转
    select LEFT('abcdefg',2);
    select RIGHT('abcdefg',2);
    select REVERSE('hijklmn');
    select REPLACE('abcdefg','abc','x');
    
    • 1
    • 2
    • 3
    • 4

    ✒️日期和时间函数

    date,time,datetime,timestamp,year。

    📌获取时间和日期

    • 【curdate】和【current_date】,返回当前的系统日期。
    • 【curtime】和【current_time】,返回当前的系统时间。
    • 【now】和【sysdate】,返回当前的系统时间和日期。
    select CURRENT_DATE();
    select CURTIME();
    select now();
    
    • 1
    • 2
    • 3

    📌时间戳和日期转换函数

    • 【UNIX_TIMESTAMP】获取unix时间戳函数
    • 【FROM_UNIXTIME】将时间戳转换为时间格式
    select UNIX_TIMESTAMP();
    select FROM_UNIXTIME(1660785720);
    
    • 1
    • 2

    📌根据日期获取年月日的数值

    select MONTH(SYSDATE());
    select MONTHNAME(SYSDATE());
    select DAYNAME(SYSDATE());
    select DAYOFWEEK(SYSDATE());
    select WEEK(SYSDATE());
    select DAYOFMONTH(SYSDATE());
    select YEAR(SYSDATE());
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    📌时间日期的计算

    -- 日期加法
    select DATE_ADD(SYSDATE(),INTERVAL 70 DAY);
    -- 日期减法
    select DATE_SUB(SYSDATE(),INTERVAL 10 DAY);
    -- 时间间隔
    select DATEDIFF('2023-01-01',SYSDATE());
    -- 日期格式化
    select DATE_FORMAT(SYSDATE(),'%W %M %D %Y');
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    ✒️加密函数

    -- 把传入的参数的字符串按照md5算法进行加密,得到一个32位的16进制的字符串
    select MD5('123456');
    
    • 1
    • 2

    md5算法是不可逆的。

    ✒️流程控制函数

    可以进行条件判断,用来实现SQL语句的逻辑。

    • if(test,t,f):如果test是真,则返回t,否则返回f
    • ifnull(arg1,arg2):如果arg1不是空,返回arg1,否则返回arg2
    • nullif(arg1,arg2):如果arg1=arg2返回null,否则返回arg1
    select IF(2 > 1,'a','b');
    select IFNULL(sal,0);
    select NULLIF(age,0);
    
    • 1
    • 2
    • 3

    对一系列的值进行判断:

    -- 输出学生的各科的成绩,以及评级,60以下D,60-70是C,71-80是B,80以上是A
    SELECT
    	*,
    CASE
    		
    		WHEN score < 60 THEN 'D' WHEN score >= 60 
    		AND score < 70 THEN 'C' WHEN score >= 70 
    			AND score < 80 THEN 'B' WHEN score >= 80 THEN
    				'A' 
    			END AS '评级' 
    	FROM
    	mystudent;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    -- 行转列
    SELECT
    	user_name,
    	max( CASE course WHEN '数学' THEN score ELSE 0 END ) '数学',
    	max( CASE course WHEN '语文' THEN score ELSE 0 END ) '语文',
    	max( CASE course WHEN '英语' THEN score ELSE 0 END ) '英语' 
    FROM
    	mystudent 
    GROUP BY
    	user_name
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    ✏️数据库设计

    ✒️三范式

    • 第一范式:要求有主键,并且要求每一个字段的原子性不能再分。
    • 第二范式:要求所有的非主键字段完全依赖主键,不能产生部分依赖
    • 第三范式:所有非主键字段和主键字段之间不能产生传递依赖。

    📌第一范式

    不符合第一范式表结构:

    idname联系方式
    1001aaa[aaa@163.com , 13314569878](mailto:aaa@163.com , 13314569878)
    1002bbb[bbb@163.com , 13245678945](mailto:bbb@163.com , 13245678945)
    1003ccc[ccc@163.com , 15000456987](mailto:ccc@163.com , 15000456987)

    符合第一范式的表结构:

    idname邮箱手机号
    1001aaaaaa@163.com12321321321
    1002bbbbbb@163.com32132654654
    1003cccccc@163.com45654654654

    必须有主键,这是数据库设计的基本要求,一般情况下我们采用数值型或定长字符串,列不能再分,比如:联系方式。

    关于第一范式,保证每一行的数据是唯一,每个表必须有主键。

    📌第二范式

    建立在第一范式的基础上,要求所有非主键字段完全依赖于主键,不能产生部分依赖。

    学号性别姓名课程编号课程名称教室成绩
    1001a2001java30189
    1002b2002mysql30290
    1003c2003html30391
    1004d2004python30452
    1005e2005c++30567
    1006f2006c#30684

    解决方案:

    学生表:学号是主键

    学号性别姓名
    1001a
    1002b
    1003c
    1004d
    1005e
    1006f

    课程表:课程编号是主键

    课程编号课程名称教室
    2001java301
    2002mysql302
    2003html303
    2004python304
    2005c++305
    2006c#306

    成绩表:学号和课程编号为联合主键

    学号课程编号成绩
    1001200189
    1002200290
    1003200391
    1004200452
    1005200567
    1006200684

    📌第三范式

    建立在第二范式基础上,非主键字段不能传递依赖于主键字段。

    不满足第三范式:

    学号姓名课程编号课程名称
    1001a2001java
    1002b2002mysql
    1003c2003html
    1004d2004python
    1005e2005c++
    1006f2006c#

    解决方案:

    学生表:学号是主键

    学号姓名课程编号
    1001a2001
    1002b2002
    1003c2003
    1004d2004
    1005e2005
    1006f2006

    课程表:课程编号是主键

    课程编号课程名称
    2001java
    2002mysql
    2003html
    2004python
    2005c++
    2006c#

    ✒️常见的表关系

    📌一对一

    学生信息表分为基本信息表和信息信息表。

    • 分为两张表,共享主键。
    • 分两张表,用外键连接。

    📌一对多

    两张表,外键在多的一方。

    • 分两张表存储,在多的一方加外键
    • 这个外键字段引用是一的一方的主键

    📌多对多

    • 分三张表存储,在学生表存储学生信息,在课程表存储课程信息。
    • 在成绩表中存储学生和课程的对应关系。

    mysql未完待续…

    索引视图,存储过程,触发器,函数…

    ✏️JDBC

    导入外部依赖
    需要引入mysql的驱动 (指的是引入的Jar包)
    数据的持久化
    把数据永久的保存起来。主要的方式还是存到硬盘上,持久化的实现过程大部分是通过数据库来完成。
    JDBC:
    1.数据库的驱动 :java.sql.Driver接口,所有驱动程序都需要接口
    mysql:com.mysql.jdbc.Driver
    反射:Class.forName(“com.mysql.jdbc.Driver”)
    2.URL地址:
    jdbc协议 jdbc:mysql://主机名称(地址):端口号/数据库名
    jdbc:mysql://127.0.0.1:3306/pan?useUnicode=true&characterEncoding=utf8
    8.0版本还需要传参useSSL=false&serverTimezone=UTC(时区)
    3.用户名
    4.密码

    8.0
    import org.junit.Test;
    
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.SQLException;
    import java.util.Objects;
    
    public class Ch01 {
        @Test
        public void test02() throws ClassNotFoundException, SQLException {
            // 数据库的url
            String url = "jdbc:mysql://127.0.0.1:3306/my?useUnicode=true&characterEncoding=utf8&useSSL=false&serverTimezone=UTC&rewriteBatchedStatements=true";
            String username = "";
            String password = "";
            // 驱动的全类名
            String driverName = "com.mysql.cj.jdbc.Driver";
    
            // 1.加载驱动类
            Class.forName(driverName);
            // 4.获取连接
            Connection connection = DriverManager.getConnection(url, username, password);
            System.out.println(connection);
            System.out.println(Objects.nonNull(connection) ? "数据库连接成功" : "数据库连接失败");
        }
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27

    5.7

    @Test
      public void test02() throws ClassNotFoundException, SQLException {
        // 数据库的url
        String url = "jdbc:mysql://127.0.0.1:3306/jsoft?useUnicode=true&characterEncoding=utf8";
        String username = "";
        String password = "";
        // 驱动的全类名
        String driverName = "com.】mysql.jdbc.Driver";
    
        // 1.加载驱动类
        Class.forName(driverName);
        // 4.获取连接
        Connection connection = DriverManager.getConnection(url, username, password);
        System.out.println(connection);
        System.out.println(Objects.nonNull(connection) ? "数据库连接成功" : "数据库连接失败");
      }
    
    执行数据库的增删改
    Java当中有3个接口分别定义了对数据库的调用的不同的方式。
    1.Statement:用来执行静态sql语句,并返回它所生成的结果对象
    2.PreparedStatement:预编译,可以使用此对象多次高效的执行该语句
    CallableStatement:用来执行sql存储过程高
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    必看

    算法对程序员来说及其重要,语言和开发平台不断变化,但是万变不离其宗的是那些算法和理论,刷算法最最最直白的原因就是找一个好的工作,那刷题一定是必不可少的
    现在算法刷题平台还是蛮多的,给大家介绍一个我认为与大厂关联最深的平台——牛客网
    在这里插入图片描述

    相较于其他平台,他们的题单更和工作,大厂靠拢,不光有面试必刷的101到题目,还有大量大厂真题,内容也全程免费,相较于其它会员费结算的来说 非常的友好
    在这里插入图片描述

    牛客网还支持ACM模式,没有练习过的一定要提前适应!像某团、某为,都要求自己处理输入输出,如果不提前练习会很吃亏的!
    牛客的题解更新迭代也很快,讨论区也有奇技淫巧的分享,能帮你把所有盲点扫清楚,整体来说还是非常推荐去练习的~
    传送门:牛客网

  • 相关阅读:
    机械转码日记【23】模板进阶
    什么是关键信息基础设施及其安全保护条例
    Ubuntu安装Netron并创建快捷键启动图标
    20240301-2-ZooKeeper面试题(二)
    Spring Boot 使用Knife4j
    python -正则表达式基础
    [附源码]计算机毕业设计基于Springboot学生社团信息管理系统
    (三)基于docker-compose的微服务编排实践-搭建nacos
    nginx基本配置参数
    低代码维格云明细视图入门教程
  • 原文地址:https://blog.csdn.net/weixin_49405762/article/details/126414714