首页 > 其他分享 >2022-08-18 第四组 王佳齐 学习笔记

2022-08-18 第四组 王佳齐 学习笔记

时间:2022-08-18 18:35:50浏览次数:48  
标签:范式 王佳齐 -- 18 mysql 第四组 com 主键 select

思维导图

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):四舍五入,负数时四进五舍,和java不同
  • 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);

字符串型函数

对字符串进行处理。

  • 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');

日期和时间函数

date,time,datetime,timestamp,year。

获取时间和日期

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

时间戳和日期转换函数

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

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

select MONTH(SYSDATE());
select MONTHNAME(SYSDATE());
select DAYNAME(SYSDATE());
select DAYOFWEEK(SYSDATE());
select WEEK(SYSDATE());
select DAYOFMONTH(SYSDATE());
select YEAR(SYSDATE());

时间日期的计算

-- 日期加法
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');

加密函数

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

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);

对一系列的值进行判断:

-- 输出学生的各科的成绩,以及评级,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;
-- 行转列
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

数据库设计

三范式

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

第一范式

不符合第一范式表结构:

id name 联系方式
1001 aaa [[email protected] , 13314569878](mailto:[email protected] , 13314569878)
1002 bbb [[email protected] , 13245678945](mailto:[email protected] , 13245678945)
1003 ccc [[email protected] , 15000456987](mailto:[email protected] , 15000456987)

符合第一范式的表结构:

id name 邮箱 手机号
1001 aaa [email protected] 12321321321
1002 bbb [email protected] 32132654654
1003 ccc [email protected] 45654654654

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

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

第二范式

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

学号 性别 姓名 课程编号 课程名称 教室 成绩
1001 a 2001 java 301 89
1002 b 2002 mysql 302 90
1003 c 2003 html 303 91
1004 d 2004 python 304 52
1005 e 2005 c++ 305 67
1006 f 2006 c# 306 84

解决方案:

学生表:学号是主键

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

课程表:课程编号是主键

课程编号 课程名称 教室
2001 java 301
2002 mysql 302
2003 html 303
2004 python 304
2005 c++ 305
2006 c# 306

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

学号 课程编号 成绩
1001 2001 89
1002 2002 90
1003 2003 91
1004 2004 52
1005 2005 67
1006 2006 84

第三范式

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

不满足第三范式:

学号 姓名 课程编号 课程名称
1001 a 2001 java
1002 b 2002 mysql
1003 c 2003 html
1004 d 2004 python
1005 e 2005 c++
1006 f 2006 c#

解决方案:

学生表:学号是主键

学号 姓名 课程编号
1001 a 2001
1002 b 2002
1003 c 2003
1004 d 2004
1005 e 2005
1006 f 2006

课程表:课程编号是主键

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

常见的表关系

一对一

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

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

一对多

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

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

多对多

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

mysql未完待续....

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

导入外部依赖包
需要引入mysql的驱动【指的是引入jar包】
1.数据的持久化,把数据永久的保存起来。主要的方式还是存到硬盘上。
持久化的实现过程大部分是通过数据库来完成。

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/mysqldata?useUnicode=true&characterEncoding=utf8
3.用户名
root
4.密码
wangyibo
连接数据库

@Test
public void test02() throws ClassNotFoundException, NoSuchMethodException, SQLException, InvocationTargetException, InstantiationException, IllegalAccessException {
    // 数据库的url
    String url = "jdbc:mysql://127.0.0.1:3306/student?useUnicode=true&characterEncoding=utf8";
    String username = "root";
    String password = "wangyibo";
    // 驱动的全类名
    String driverName = "com.mysql.jdbc.Driver";


    // 1.加载驱动类
    Class clazz = Class.forName(driverName);
    // 2.实例化Driver对象
    Driver driver = (Driver) clazz.getDeclaredConstructor().newInstance();
    // 3.注册驱动
    DriverManager.registerDriver(driver);
    // 4.获取连接
    Connection connection = DriverManager.getConnection(url, username, password);
    System.out.println(connection);
    System.out.println(Objects.nonNull(connection) ? "数据库连接成功" : "数据库连接失败");
}
------------------------------------------------------------------------------
-------------------------------------------------------------------------------
@Test
public void test03() throws ClassNotFoundException, SQLException {
    // 数据库的url
    String url = "jdbc:mysql://127.0.0.1:3306/mydatas?useUnicode=true&characterEncoding=utf8";
    String username = "root";
    String password = "wangyibo";
    // 驱动的全类名
    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) ? "数据库连接成功" : "数据库连接失败");

使用属性文件的好处:
1.实现了代码和数据的分离,如果需要修改配置信息,直接在属性文件中修改即可,不需要深入代码
2.如果修改了配置信息,省去了编译的过程

执行数据库的DML语句--增删改
Java中三个接口分别定义了对数据库调用的不同的方式:
1.Statement:用来执行静态sql语句并返回它所生成的结果对象
2.PreparedStatement:可以使用此对象多次高效执行该语句
3.CallableStatement:用来执行sql存储过程

学习心得

今天学习了sql函数和JDBC,感觉JDBC的三个接口作用没有很理解。

标签:范式,王佳齐,--,18,mysql,第四组,com,主键,select
From: https://www.cnblogs.com/yiboxh-10000/p/16599724.html

相关文章

  • 2022-08-18 第二组刘禹彤 学习笔记
    打卡35天  ###学习内容MySQL常用函数聚合函数count:计数------------count(*)≈count(1)>count(主键)>count(字段)count(*):MySQL对count(*)底层优化----count(min:最小值......
  • 8.18总结
    泡泡堂\(solution\)苹果树\(solution\)字符合并\(solution\)脑洞治疗仪\(solution\)万万没想到,我50pts的原因是数组没开够线段树维护修改操作,注意先挖后补ACCo......
  • asp.net获取当前网址url (2018-11-02 14:49:45)
    设当前页完整地址是:http://www.jb51.net/aaa/bbb.aspx?id=5&name=kelli "http://"是协议名 "www.jb51.net"是域名 "aaa"是站点名 "bbb.aspx"是页面名(文件名) "id=......
  • 手机网页限制用户缩放代码 (2014-03-25 18:16:52)
    网页手机wap2.0网页的head里加入下面这条元标签,在iPhone的浏览器中页面将以原始大小显示,并不允许缩放。    width-viewport的宽度height-viewport的高度  initi......
  • 8.18集训
    回到了Luogu,继续刷COCI……上午事实证明后三题是可做题,前三题不大可做。T1P6405开始码了一个相邻的树木连边,边权设为相等的时间,然后点边互换跑连通块算大小,默认恒等......
  • 黑莓Z10变砖后自己刷机 (2014-01-17 18:46:36)
     解决办法一:强制刷机刷机开始之前,请查看Z10的型号目前有STL100-1100-2100-3大家可以在手机设置,关于中找到,或者去说明书中查看。目前亚洲非洲版为100-1也就是得州处......
  • NOIP2022模拟赛一 By RSJ 08.18
    A.「NOIP2022模拟赛一ByRSJ」StringSearchPro给定一个\(01\)字符串,查找一个子串使得\(0\)在这个子串中出现了\(\frac{p}{q}\cdotk\)次,其中\(k\)是子串长度\(n,p,q......
  • 18、函数递归
    18、函数递归  目录:一函数递归调用介绍二回溯与递推视频链接 一函数递归调用介绍函数不仅可以嵌套定义,还可以嵌套调用,即在调用一个函数的过......
  • 2022/8/18 动态规划复习(内含Caesar's Legions,数字游戏,合唱队形,The Battle of Chibi,Que
    QueriesforNumberofPalindromes标签:回文类区间dp 一道典型的区间dp。注意求的是个数而不是长度。初始化的时候注意一下,len=2时分两种情况。ch[i]=ch[i-1]时,dp[i-......
  • Parallels18永久使用版
    mac软件下载:https://mac.macxf.com/mac/3815.html?id=NjU2MTE%3DParallelsDesktop18简称PD18,一款在Mac上同时运行macOS和Windows,支持Intel和M芯片的虚拟机,在Mac与Win......