2022-8-18 第一小组 (≥▽≤) 学习笔记

1.MySQL常用函数

1.1 聚合函数

  • count

    • 计数。count(*)≈count(1)>count(主键)
      • count(*):MySQL对count(*)底层优化,count(0)
      • count(1)
      • count(主键)
      • count(字段)
  • min:最小值

  • max:最大值

  • sum:求和

  • avg:平均

1.2 数值型函数

主要是对数值型进行处理

  • ceiling(x):向上取整
  • floor(x):向下取整
  • round(x):四舍五入
  • truncate(x,y):返回数字x截断为y位小数的结果
  • PI:圆周率,Π
  • ABS:绝对值
  • rand:返回0~1的随机数
  • MOD:取余
SELECT CEILING(-11.1) AS 向上取整,FLOOR(-11.1) AS 向下取整,ROUND(-11.1) AS 四舍五入;
-- --------- 
SELECT RAND() AS 随机数,ROUND(RAND()*99+1)  AS 随机整数;

1.3字符串型函数

对字符串进行处理。

  • 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('阿瓦达',1) AS 返回左边1个字符;

SELECT RIGHT('阿瓦达',1) AS 返回右边1个字符;

SELECT REVERSE('阿瓦达') AS 反转;

SELECT REPLACE('阿瓦达','达','啃瓜') AS 替换;

1.4日期和时间(重要)

获取日期和时间

date,time,datetime,timestamp,year

  • 【current】和【current_date】:返回当前的系统日期。

  • 【curtime】和【curtime_time】:返回当前的系统时间。

  • 【now】和【sysdate】:返回当前的系统时间和日期。

  • SELECT CURRENT_DATE();
    SELECT CURTIME();
    SELECT NOW();
    

时间戳和日期转换函数

  • 【UNIX_TIMESTAMP()】:获取unix时间戳函数

  • 【FROM_UNIXTIME】将时间戳转换为时间格式

  • SELECT  UNIX_TIMESTAMP();
    SELECT FROM_UNIXTIME(1660785826);
    

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

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

1.5加密函数

-- 会获得
SELECT MD5(MD5(MD5(MD5(MD5(MD5('247858'))))))

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

2.数据库设计

三范式

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

第一范式

  • 必须有主键,这是数据库设计的基本要求,一般情况下我们采用数值型或定长字符串,列不能再分
  • 关于第一范式,保证每一行的数据唯一,每个表必须要有主键

第二范式

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

第三范式

  • 在第二范式的基础上,所有的非主键字段不能依赖

常见的表关系

一对一

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

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

一对多

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

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

多对多

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

3.JDBC

  • 导入外部依赖
  • 需要引用mysql的驱动(指的是引入的jar包)
    • 数据的持久化,把数据永久的保存起来。主要的方式还是存到硬盘上。
    • 持久化的实现过程大部分是通过数据库来完成的。
  • JDBC:是通过Java来操作数据库的
    • 数据库的驱动:java.sql.Driver接口,所有的驱动程序需要实现的接口
      • mysql:(com.mysql.cj.jdbc.Driver)
      • Oracle:oracle.jdbc.driver.OracleDriver
      • 反射,Class.forName(“com.mysql.cj.jdbc.Driver”)
    • URL地址:
      • jdbc协议
      • jdbc:mysql://主机名称:端口号/数据库的名
      • jdbc:mysql://localhost:3306/jsoft?useUnicode=true*characterEncoding=utf8
      • 8.0(版本)还需要传参useUnicode=true*characterEncoding=utf8?useSSL=false&serverTimezone=UTC
    • 用户名
      • root
    • 密码
      • 3306
  • 使用属性文件的好处:
    • 实现了代码的和数据的分离,如果需要修改,可以直接在属性文件中修改即可,
  • Java中3个接口分别定义了对数据库的调用的不同方式
    • Statement——用来执行静态SQL并返回所生成的结果对象
    • PreparedStatement——预编译,可以使用此对象多次高效的执行该语句
    • CallableStatement——用来执行sql的存储过程
posted @ 2022-08-18 19:53  (≧∇≦)(≧∇≦)(≧∇≦)  阅读(37)  评论(0)    收藏  举报