MySQl & Mybatis

本文详细介绍了MySQL的基础概念、数据定义语言(DDL)如表结构操作、数据操纵语言(DML)如增删改查,以及数据查询语言(DQL)。此外,还涵盖了Mybatis的入门、JDBC使用示例、数据库连接池和基础操作,包括动态SQL的if、foreach和sqlinclude部分。
摘要由CSDN通过智能技术生成

 

一、MySQL

1.1 概述

 1.1.1 MySQL安装

 

1.1.2 数据模型

1.1.3 SQL简介

 

1.2 DDL

1.2.1 数据库操作

 

1.2.2 图形化工具

 

 

1.2.3 表结构操作

 (一)创建

(二)数据类型 

(1)数值类型

age tinyint unsigned——加上unsigned就是不能取负数,将取值范围取正数区间变大。

(2)字符串类型

char(10):最多只能存储10个字符,不足10个字符,占用10个字符空间(性能较高、浪费空间)

varchar(10): 最多只能存储10个字符,不足10个字符,按照实际长度存储(性能较低、节省空间)

 (3)日期类型

(三)查询
 (四)修改

(五)删除

 

1.3 DML

1.3.1 添加数据insert

1.3.2 修改数据update

1.3.3 删除数据delete

1.4 DQL

1.4.1 基本查询

 

 1.4.2 条件查询

 

 

1.4.3 聚合函数

1.4.4 分组查询

1.4.5 排序查询

 

1.4.6 分页查询

 

1.5 多表设计

1.5.1 一对多

 

 

1.5.2 一对一

1.5.3 多对多

1.6 多表查询

1.6.1 概述

 

1.6.2 内连接

1.6.3 外连接

1.7 子查询

1.7.1 标量子查询

 

1.7.2 列子查询

1.7.3 行子查询

1.7.4 表子查询

1.8 事务

1.8.1 介绍与操作

 

1.8.2 四大特性

1.9 索引

1.9.1 介绍

1.9.2 结构

1.9.3 操作语法

2 Mybatis

2.1 入门

2.1.1 介绍

2.1.2 快速入门程序

 

 

 

2.1.3 JDBC介绍

(一)JDBC操作数据库

package com.itheima;

import com.itheima.mapper.UserMapper;
import com.itheima.pojo.User;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.sql.*;
import java.util.ArrayList;
import java.util.List;

@SpringBootTest //springboot整合单元测试的注解
class SpringbootMybatisQuickstartApplicationTests {

    @Autowired
    private UserMapper userMapper;

    @Test
    public void testListUser(){
        List<User> userList = userMapper.list();
        userList.stream().forEach(user -> {
            System.out.println(user);
        });
    }

    @Test
    public void testJdbc() throws Exception {
        //1. 注册驱动
        Class.forName("com.mysql.cj.jdbc.Driver");

        //2. 获取连接对象
        String url = "jdbc:mysql://localhost:3306/mybatis";
        String username = "root";
        String password = "1234";
        Connection connection = DriverManager.getConnection(url, username, password);

        //3. 获取执行SQL的对象Statement,执行SQL,返回结果
        String sql = "select * from user";
        Statement statement = connection.createStatement();
        ResultSet resultSet = statement.executeQuery(sql);

        //4. 封装结果数据
        List<User> userList = new ArrayList<>();
        while (resultSet.next()){
            int id = resultSet.getInt("id");
            String name = resultSet.getString("name");
            short age = resultSet.getShort("age");
            short gender = resultSet.getShort("gender");
            String phone = resultSet.getString("phone");

            User user = new User(id,name,age,gender,phone);
            userList.add(user);
        }

        //5. 释放资源
        statement.close();
        connection.close();
    }
}

 输出:

 

 

2.1.4 数据库连接池

 

 

 

2.1.5 lombook

 

 

2.2 基础操作

2.2.1 环境准备

 

2.2.2 删除

(一)根据主键删除

 

若想获取删除了几条数据的返回值:

 

输出:0

(二)日志输出

 

 

2.2.3 新增

 

 

2.2.4 更新 

2.2.5 查询

(一)主键查询

 

解决方案一:给字段起别名,让别名与实体类属性一致

解决方案二:通过@Results,注释手动映射封装 

解决方案三:开启mybatis驼峰命令自动映射开关

 直接运行原始代码就可以

总结:

(二)条件查询

 

 

2.3 XML映射文件

 Mapper接口全限定名可以 选中接口名称-copy reference-粘贴到namespace

 

 

2.4 动态SQL 

2.4.1 if

 

 

 

 

 

 

2.4.2 foreach

 

 

2.4.3 sql include

 

  • 35
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值