springboot+jpa+mysql Springboot+jpa+jdbc+sqlserver 使用时遇到的一系列的问题

更改背景

正在做一个微信小程序的前后端项目,一开始使用的是springboot+jpa+mysql,但负责接受数据存入数据库的负责人执意要用sqlserver。本来微信小程序前端,以及spring boot利用jpa操作mysql的数据库都已经编写好了,但拗不过他,因为他是老师,我是学生,只能下点功夫更改。
一开始负责小程序前端,对接口这块本来就不太熟,包括对框架,jpa的概念都不熟悉。本来不是个大问题,但中途走了很多弯路,还踩了Mybait的坑出现了一系列的问题,所以在此写出来,希望大家遇到相同的问题能够尽快解决。

一些基本概念

springboot:一个框架。我对框架的理解就是提供一套三室两厅的毛坯房子,给你分好了每一个房间的大小,位置,形状,中间用墙间隔开。不同的房间有着不同的用处,我们要把这套房装修成自己想要的样子。那好,根据原来分割好的房间,我在厨房安装炒菜的灶台,洗菜刷碗的水龙头,在卧室安装放衣服的橱柜,睡觉的床,在客厅安装电视机,沙发等等,房间之间都可以联通。但是如果没有框架怎么办?你有一套130平米的房子,就一个房间,从一端可以看到另一端,没有任何墙阻隔,像一个仓库,这时你要把它装修成你想要的样子,没办法划分,把所有的东西全放这样一个房间里,即便摆放再整齐,也会看上去很凌乱,找东西不方便。
JPA:对象关系的映射标准。(具体不太懂)是一种允许在代码和数据库表的对象之间进行映射的技术。这可以从开发人员那里“隐藏”SQL,以便他们处理所有内容都是Java类,并且提供程序允许他们并以神奇的方式加载他们。我的理解就是使用JPA后就不用再写一些SQL语句了,可以通过一个特定条语句直接代替,代码看起来很简洁。下面会分享我的代码,可以看一下。
JDBC:一种用于执行SQL语句的Java API,可以为多种数据库提供统一的访问接口。还有提到很多的就是JDBC驱动程序,我觉得就像单片机的CH340驱动芯片,只有安装这个驱动程序,单片机才能连接上位机。在查资料时,书中说:如果更换数据库,基本上只要更换驱动程序,Java程序中只要加载新的驱动来源,即可完成数据库系统的变更,Java无须改变。这句话给了我很大的启发,把我的思路从弯路上拉了回来,但实际情况也没那么简单。
maven:是个管理工具。具体我也不知道是个啥,这就不得不提pom.xml文件,总觉得他们相关。是要通过pom.xml文件创建maven的依赖,这个pom.xml文件是个好东西,可以加入各种依赖,就像毛坯房里的用电开关,每个房间都要在这个大开关上引上小开关供电,才能给每个房间通电,房间里的电器才能正常运作。
**Mysql与sqlserver:**两者都是基于SQL,但语法上的差异仍然很突出。如果用MySQL个人感觉用Navicat for MySQL可视化界面,非常好用,之前用了Mysql workbench,体验感贼差。当然我用的IDEA的集成开发环境自带数据库的可视化操作,可连接各种数据库。
**mybatis:**是一种半自动的ORM持久层框架,具有较高的SQL灵活性,支持高级映射(一对一,一对多)。。。。反正如果要用它,要什么各种映射mapper,初学者不经过系统的学一学,不怎么好明白。具体有什么好处,倒是没感觉出来有一篇介绍比较全的博客。关于mybatis

常见的错误与警告

sqljdbc的驱动引入:引入方式有两种。建议用第二种。
第一种:
在pom.xml文件中引入sqljdbc依赖。

<dependency>
<groupId>com.microsoft.sqlserver</groupId>
 <artifactId>sqljdbc4</artifactId> 
<version>4.0</version>
</dependency>

引入后重新加载该文件,它不会自动下载,sqljdbc4会报红很奇怪。这时候就要另外下载。下载地址:sqljdbc
都选中下载会有三个文件在这里插入图片描述
会有三个文件,运行.exe文件
springboot+jpa+mysql Springboot+jpa+jdbc+sqlserver 使用时遇到的一系列的问题_第1张图片
解压到任意位置,根据Microsoft JDBC Driver 6.0 for SQL Server\sqljdbc_6.0\chs\jre8路径找到sqljdbc42.jar文件。放到C:\Users\Administrator.m2\repository\com\microsoft\sqlserver\sqljdbc4\4.0\的位置,更改命名规则 artifactId-version 比如sqljdbc4-4.0.jar 。这样就不会报红了,但有的4.0会报红,那就不知道怎么解决了。
第二种:
不需要在pom.xml文件里加依赖
点击idea的文件,选中“项目结构”。我的汉化了,如果是英文版的,根据位置定吧。
springboot+jpa+mysql Springboot+jpa+jdbc+sqlserver 使用时遇到的一系列的问题_第2张图片
点击“库”,再点击“+”,选中Java。
springboot+jpa+mysql Springboot+jpa+jdbc+sqlserver 使用时遇到的一系列的问题_第3张图片
选择第一种方法中解压出来的sqljdbc42文件,执行应用,就可以了。
springboot+jpa+mysql Springboot+jpa+jdbc+sqlserver 使用时遇到的一系列的问题_第4张图片
在项目目录中的外部依赖库会出现添加的sqljdbc42文件。添加成功,结束。
springboot+jpa+mysql Springboot+jpa+jdbc+sqlserver 使用时遇到的一系列的问题_第5张图片
pom.xml的依赖爆红
比如spring-boot-maven-plugin报红,原因是没有加版本号。怎么查自己使用的版本号呢?举个例子:
在这里插入图片描述
那么它的文件路径就是C:\Users\100T.m2\repository\org\springframework\boot\spring-boot-starter-test
找到规律了么?对了,就是这样的规律,其它的依赖也都一样都会在.m2\repository文件中。。100T是我的电脑用户名。。
idea键入变白:纯属手贱,不小心按到了。
springboot+jpa+mysql Springboot+jpa+jdbc+sqlserver 使用时遇到的一系列的问题_第6张图片
连接都正确,但收不到数据库数据
学的时候没好好学,定义实体类的文件名称必须要跟数据库的表名相同。不然运行后他会创建一个新的空的表。还有定义实体类中变量的时候,无论表的列名是大写还是小写,变量都要小写。!!!!
还遇到很多问题就不一一赘述了。。。如果你也遇到了相关的问题可以私聊我。

思路与感悟

1。。知识储备不足,一切都白扯。在做mysql的时候,完全对java,IDEA,springboot不懂,跟着视频做,可以根据自己的需求把做出来的东西进行修改,但项目结构,具体细节,一窍不通,这是走了弯路很大的原因。后期在图书馆借书查了很多资料。
2.。。思考很重要。按以往的学习方式,我首先查找java操作sqlserver的例子,出现各种版本,什么jdbc的,spring mvc,mybatis,然后我开始在不懂相关知识,毫不思考的情况下开始尝试各种方法,但每一种总是出现报错的情况,然后解决各种错误,垃圾,错误越来越多,无从下手。这时导师让我去图书馆找书先读读,过不了几天就要给厂家演示,哪还有时间,我还是拿出一天时间去查资料。玛德,果然受益匪浅,不再按网上的例子,沉下心来好好想了想怎么做这个东西,用自己的思路做。
3.。。不要坚持,及时止损。不要钻牛角尖,结合上面的2一种方法不行,及时改变方法,我就是在这个上面浪费了太多的时间。
4.。。坚持,不要放弃。似乎和上面的3有些矛盾,这里说的是做事情还是不要轻易放弃,中途那个老师也一直在说他自己编。让我明天中午去给他安装java的集成开发软件,玛德,老子上午给他编出来了。操!

附上springboot+jpa+mysql的代码

文件目录如下
springboot+jpa+mysql Springboot+jpa+jdbc+sqlserver 使用时遇到的一系列的问题_第7张图片
ShpController文件

package com.example.connect_tese_1.mysql;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

@RestController
public class ShpController {

    @Autowired
    ShpDao shpDao;
//获取所有设备的信息
    @GetMapping("/getAll")
    public  List getAll(){
        List all = shpDao.findAll();
        return all;
    }
//根据deviceid获取设备信息
    @GetMapping ("/findOne")
    public Object findOne(@RequestParam("deviceid") Integer deviceid) {
        System.out.println("deviceid="+deviceid);
        return shpDao.findByDeviceID(deviceid);
    }
    @GetMapping("/login")
    public String demo(@RequestParam("AvatarUrl") String AvatarUrl,
                       @RequestParam("nickname") String nickname,
                       @RequestParam("Province") String Province,
                       @RequestParam("City") String City,
                       @RequestParam("Country") String Country,
                       @RequestParam("Openid") String Openid) {
        System.out.println("AvatarUrl=" + AvatarUrl);
        System.out.println("nickname=" + nickname);
        System.out.println("Province=" + Province);
        System.out.println("City=" + City);
        System.out.println("Country=" + Country);
        System.out.println("Openid=" + Openid);
        return AvatarUrl;
    }
    @GetMapping("/register")
    public String demo(@RequestParam("ApiAccessToken") String ApiAccessToken,
                       @RequestParam("Mobile") String Mobile,
                       @RequestParam("Company") String Company,
                       @RequestParam("Name") String Name,
                       @RequestParam("WeiXinOpenId") String WeiXinOpenId){
        System.out.println("ApiAccessToken=" + ApiAccessToken);
        System.out.println("Mobile=" + Mobile);
        System.out.println("Company=" + Company);
        System.out.println("Name=" + Name);
        System.out.println("WeiXinOpenId=" + WeiXinOpenId);
        return Name;
    }
}

ShpDao文件

package com.example.connect_tese_1.mysql;

import org.springframework.data.jpa.repository.JpaRepository;

public interface ShpDao  extends JpaRepository <tbSHP,Integer>{

    Object findByDeviceID(Integer deviceid);
}

tbSHP文件,定义实体类的文件,太长了,不粘贴了。
application.properties文件

spring.datasource.url=jdbc:mysql://localhost:3306/数据库名?useUnicode=true&characterEncoding=utf-8&useSSL=true&serverTimezone=UTC
spring.datasource.username=用户名
spring.datasource.password=密码
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.jpa.properties.hibernate.hbm2ddl.auto=update

ConnectTese1Application文件

package com.example.connect_tese_1;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class ConnectTese1Application {

    public static void main(String[] args) {
        SpringApplication.run(ConnectTese1Application.class, args);
    }

}

pom.xml文件


```java
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.4.5</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.example</groupId>
    <artifactId>connect_tese_1</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>connect_tese_1</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>11</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>com.microsoft.sqlserver</groupId>
            <artifactId>mssql-jdbc</artifactId>
            <version>8.2.2.jre8</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- http请求工具包依赖 -->
        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpclient</artifactId>
            <version>4.5.2</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

``Springboot+jpa+jdbc+sqlserver代码

其它的都相同,唯一不同的是application.properties文件

spring.datasource.url=jdbc:sqlserver://localhost:1433;DatabaseName=数据库名字
spring.datasource.username=用户名
spring.datasource.password=密码
spring.datasource.driverClassName=com.microsoft.sqlserver.jdbc.SQLServerDriver
#spring.datasource.max-active=20
#spring.datasource.max-idle=8
#spring.datasource.min-idle=8
#spring.datasource.initial-size=10

spring.jpa.database=MySQL
spring.jpa.show-sql=true
spring.jpa.hibernate.ddl.auto=update
spring.jpa.hibernate.naming-strategy=org.hibernate.cfg.ImprovedNamingStrategy
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.SQLServer2008Dialect

一定要我用这个,我用了很多版本的类似配置语句,用别的会报错,说什么不支持virant的类型,还有各种报错,我查资料说是涉及到sqlserver的一个类型转换问题,和数据库表的列名大小写也有关系,要想弄明白还需要进一步学习一下。如果有知道的大神联系我,一起讨论一下。

就这些吧,欢迎联系交流。。。。

你可能感兴趣的:(springboot,数据库,mysql,sql,java,spring,intellij,idea)