其他分享
首页 > 其他分享> > 2022-08-18 第二小组 张鑫 学习笔记

2022-08-18 第二小组 张鑫 学习笔记

作者:互联网

实训四十天

1.学习重点

1.MySQL常用函数
2.数据库设计
3.JDBC

2.学习心得

今天的内容主要是JDBC,四天没有用idea,属实有点生疏了,要多多练习才行

3.学习内容

MySQL常用函数

聚合函数

数值型函数

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

-- 绝对值
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);

字符串型函数

对字符串进行处理。

select LEFT('abcdefg',2);
select RIGHT('abcdefg',2);
select REVERSE('hijklmn');
select REPLACE('abcdefg','abc','x');

日期和时间函数

date,time,datetime,timestamp,year。

获取时间和日期

select CURRENT_DATE();
select CURTIME();
select now();

时间戳和日期转换函数

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语句的逻辑。

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 [aaa@163.com , 13314569878]
1002 bbb [bbb@163.com , 13245678945]
1003 ccc [ccc@163.com , 15000456987]

符合第一范式的表结构:

id name 邮箱 手机号
1001 aaa [aaa@163.com] 12321321321
1002 bbb [bbb@163.com] 32132654654
1003 ccc [ccc@163.com] 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未完待续....

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

JDBC

导入外部依赖
需要引入mysql的驱动(指的是引入的jar包)

数据的持久化,把数据永久的保存起来,主要还是存在硬盘上
持久化的实现过程大部分是通过数据库来完成

JDBC:
1.数据库的驱动:java.sql.Driver接口,所有驱动程序需要实现的接口
    mysql:com.mysql.jdbc.Driver
    oracle:oracle.jdbc.driver.OracleDriver
    反射,Class.forName("com.mysql.jdbc.Driver")
2.URL地址
    jdbc协议
    jdbc:mysql://主机名称:端口号/数据库名
    jdbc:mysql://127.0.0.1:3306/jsoft?useUnicode=true&characterEncoding=utf8
    8.0版本还需要传参useSSL=false&serverTimezone=UTC
    oracle:
    jdbc:oracle:thin:@主机名称:oracle端口:数据库名
    sqlServer:微软 C#
    jdbc:sqlserver://127.0.0.1:端口号:DatabaseName=xxxx
3.用户名 root
4.密码 root

连接数据库

public void test01() throws ClassNotFoundException, NoSuchMethodException, InvocationTargetException, InstantiationException, IllegalAccessException, SQLException, SQLException, InvocationTargetException {
        // 数据库的url
        String url = "jdbc:mysql://127.0.0.1:3306/jsoft?useUnicode=true&characterEncoding=utf8";
        String username = "root";
        String password = "root";
        // 驱动的全类名
        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) ? "数据库连接成功" : "数据库连接失败");
    }

执行数据库的DML语句--增删改

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

案例

Teacher类

public class Teacher {

    private Integer id;
    private String name;

    public Teacher() {
    }

    public Teacher(Integer id, String name) {
        this.id = id;
        this.name = name;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public String toString() {
        return "Teacher{" +
                "id=" + id +
                ", name='" + name + '\'' +
                '}';
    }
}

TeacherDao 类

public class TeacherDao {


    Connection conn = null;
    Statement stmt = null;

    {
        conn = JDBCUtil.getConnection();
        try {
            stmt = conn.createStatement();
        } catch (SQLException e) {
            throw new RuntimeException(e);
        }
    }

    /*
        这个方法是增删改
     */
    public int update(String sql,Object ... args) throws SQLException {
        return stmt.executeUpdate(sql);
    }

    /*
        查询所有
     */
    public List<Teacher> queryAll(String sql) throws SQLException {
        List<Teacher> teachers = new ArrayList<>(16);
        ResultSet rs = stmt.executeQuery(sql);
        while(rs.next()) {
            int id = rs.getInt(1);
            String name = rs.getString(2);
            Teacher teacher = new Teacher(id,name);
            teachers.add(teacher);
        }

        return teachers;
    }

}

TeacherDaoTest 类

public class TeacherDaoTest {

    private TeacherDao teacherDao = new TeacherDao();

    @Test
    public void test01() {

        try {
            teacherDao.update("delete from teacher where id = 7");
        } catch (SQLException e) {
            throw new RuntimeException(e);
        }
    }

    @Test
    public void test02() {

        try {
            List<Teacher> teachers = teacherDao.queryAll("select * from teacher");
            System.out.println(teachers);
        } catch (SQLException e) {
            throw new RuntimeException(e);
        }
    }


}

标签:name,--,张鑫,08,public,18,id,主键,select
来源: https://www.cnblogs.com/zxscj/p/16600092.html