MySQL语法及IDEA使用MySQL大全

        在项目中我们时常需要写SQL语句,或简单的使用注解直接开发,或使用XML进行动态SQL之类的相对困难的SQL,并在IDEA中操控我们的SQL,但网上大都图方便或者觉得太简单了,完全没一个涵盖两个方面的讲解。

单表:

        DDL(表操作):

创表语句:

MySQL语法及IDEA使用MySQL大全

 约束:

MySQL语法及IDEA使用MySQL大全


常见的数据类型:

MySQL语法及IDEA使用MySQL大全

MySQL语法及IDEA使用MySQL大全MySQL语法及IDEA使用MySQL大全

for example(例子):

create table address_book
(
    id            bigint auto_increment comment '主键'
        primary key,
    user_id       bigint                       not null comment '用户id',
    consignee     varchar(50)                  null comment '收货人',
    sex           varchar(2)                   null comment '性别',
    phone         varchar(11)                  not null comment '手机号',
    province_code varchar(12) charset utf8mb4  null comment '省级区划编号',
    province_name varchar(32) charset utf8mb4  null comment '省级名称',
    city_code     varchar(12) charset utf8mb4  null comment '市级区划编号',
    city_name     varchar(32) charset utf8mb4  null comment '市级名称',
    district_code varchar(12) charset utf8mb4  null comment '区级区划编号',
    district_name varchar(32) charset utf8mb4  null comment '区级名称',
    detail        varchar(200) charset utf8mb4 null comment '详细地址',
    label         varchar(100) charset utf8mb4 null comment '标签',
    is_default    tinyint(1) default 0         not null comment '默认 0 否 1是'
)
    comment '地址簿' collate = utf8mb3_bin;

          

查询语句:

MySQL语法及IDEA使用MySQL大全

修改语句:

                                                                            MySQL语法及IDEA使用MySQL大全   那么IDEA中是如何操作DDL语句的呢?                                 MySQL语法及IDEA使用MySQL大全MySQL语法及IDEA使用MySQL大全               需要特别说的是,IDEA中想执行哪部分代码,就左键选中代码块变色,再点击绿色的执行按钮 

DML  :             

insert

MySQL语法及IDEA使用MySQL大全

@Insert("insert into category(type, name, sort, status, create_time, update_time, create_user, update_user)" +
            " VALUES" +
            " (#{type}, #{name}, #{sort}, #{status}, #{createTime}, #{updateTime}, #{createUser}, #{updateUser})")
       insert into dish_flavor (dish_id, name, value)
       value
       
           (#{df.dishId},#{df.name},#{df.value})
       
    

Update

MySQL语法及IDEA使用MySQL大全

 
# yml中配置文件加的开启驼峰命名,只是java中Employee 类的 成员变量的驼峰命名 可以对应 数据库中的 参数名
        update employee
        
            
                name = #{name},
            
            
                username = #{username},
            
            
                password = #{password},
            
            
                phone =#{phone},
            
            
                sex = #{sex},
            
            
                id_Number = #{idNumber},
            
            
                status = #{status},
            
            
                update_Time = #{updateTime},
            
            
                update_User = #{updateUser},
            
        
        where id = #{id}
    

项目里一般都是动态SQL编辑数据,简单的update直接使用MP,根本没必要写

Delete

MySQL语法及IDEA使用MySQL大全

 @Delete("delete from dish_flavor where dish_id = #{dishid}")
    void deleteByDishId(Long dishid);
        delete from dish_flavor where dish_id in
        
            #{dishId}
        
    

DQL:

MySQL语法及IDEA使用MySQL大全

基本查询:

MySQL语法及IDEA使用MySQL大全

注意:代码中*是通配符,即查询所有

条件查询:

MySQL语法及IDEA使用MySQL大全

聚合函数:

MySQL语法及IDEA使用MySQL大全

分组查询:

MySQL语法及IDEA使用MySQL大全

排序查询:

MySQL语法及IDEA使用MySQL大全

分页查询:

MySQL语法及IDEA使用MySQL大全

但分页查询,不同于其他的DQL查询方式,它是项目较为重要的部分,我们一般会使用PageHelper这个插件,来简化我们的代码,以下是

分页查询的三点重要的步骤:

First:

       先pom.xml导入maven对应依赖

            com.github.pagehelper
            pagehelper-spring-boot-starter
        

Second:

        在impl中写模板式代码

 public PageResult pageQuery( EmployeePageQueryDTO employeePageQueryDTO) {
//        select * from employee limit 0,10
//        开始分页查询
        PageHelper.startPage(employeePageQueryDTO.getPage(),employeePageQueryDTO.getPageSize());
//      这个是强制要求名字叫”page“,不能改,所以这需要创建对象
        Page page = employeeMapper.pageQuery(employeePageQueryDTO);

//        long total1 = employeeMapper.pageQuery(employeePageQueryDTO).getTotal();
//        List records1 = employeeMapper.pageQuery(employeePageQueryDTO).getResult();

        long total = page.getTotal();
        List records = page.getResult();

        return new PageResult(total,records);
    }

Third:

        select * from employee
        
            
                and name like concat('%',#{name},'%')
            
        
        order by create_time desc
    

多表:

分为逻辑外键和物理外键,见名知意,前者并没有物理层面的约束,后者则是有着物理层面的约束

MySQL语法及IDEA使用MySQL大全

以上是一份逻辑关联的SQL语句,这应该是企业最常用的方式

但,此方法也有缺点,若你没考虑周全,可能会误操作,所以物理外键可能更利于你保持数据完整性和同一性。

MySQL语法及IDEA使用MySQL大全

IDEA修改方法:

MySQL语法及IDEA使用MySQL大全

MySQL语法及IDEA使用MySQL大全

根据名称,进行添加,修改外键

多表查询:

先简单介绍一下笛卡尔积,两个集合一个集合数据量为2,另一个数据量为4,两个相乘则为8条,这就是笛卡尔积,

而我们肯定不需要冗余数据,所以需要消除冗余项

MySQL语法及IDEA使用MySQL大全

分类:

MySQL语法及IDEA使用MySQL大全

内连接就是取并集,外连接就是取AorB,子查询则是查询蓝色or橘色部分

内连接:

MySQL语法及IDEA使用MySQL大全

外连接:

 MySQL语法及IDEA使用MySQL大全

子查询:

MySQL语法及IDEA使用MySQL大全

总结代码:

        select  d.* , c.name as category_name  from dish d left outer join category c on d.category_id = c.id
        
            
                and d.name like concat('%',#{name},'%')
            
            
                and d.category_id = #{categoryId}
            
            
                and d.status = #{status}
            
        
        order by d.create_time desc
    

事务:

MySQL语法及IDEA使用MySQL大全

MySQL语法及IDEA使用MySQL大全

注意:

● 默认MySQL的事务是自动提交的,也就是说,当执行一条DML语句, MySQL会 立即隐式的提交事务。

MySQL语法及IDEA使用MySQL大全

索引:

当数据库的表中数据量很大时,DML等SQL语句会有很长的时耗。

索引(index)是帮助数据库高效获取数据的数据结构
MySQL语法及IDEA使用MySQL大全

MySQL语法及IDEA使用MySQL大全

..

语法:

MySQL语法及IDEA使用MySQL大全

本文来自网络,不代表协通编程立场,如若转载,请注明出处:https://net2asp.com/d056cec6f9.html