项目技巧二

news2024/11/25 14:27:51

java中Date和mysql数据库datetime数据类型 

  1. 数据库中的 datetime 类型

    • 大多数关系型数据库(如 MySQL, SQL Server, PostgreSQL 等)都提供了 datetime 类型,用于存储日期和时间信息。
    • 这些数据库中的 datetime 类型通常遵循 ISO 8601 标准,能够存储从 '0001-01-01 00:00:00' 到 '9999-12-31 23:59:59' 的日期和时间。
    • 具体的精度和存储方式可能因数据库系统的不同而有所差异。
  2. Java 中的 Date 类型

    • Java 的 java.util.Date 类代表一个特定的瞬间,精确到毫秒。
    • Date 对象包含从“标准基准时间”(即格林威治时间 1970 年 1 月 1 日 00:00:00)至今的毫秒数。
    • Date 类本身不包含时区信息,它只是表示一个时间点。

注意:

1.我们可以直接使用Date数据类型来与datetime数据类型直接比较,如

where datetime = Date 

2.从数据库中查询datetime数据类型时,会直接得到一个Date数据类型

3.将Date数据类型插入数据库时,需要把Date数据类型转换成特定格式的时间String数据类型才能插入数据库中

如:特定string数据类型格式为 "yyyy-MM-dd HH:mm:ss" 

在yml文件中配置成员变量的值

1.写一个yml文件 

# 配置股票相关的参数
stock:
  inner:   #A股
    - sh000001 # 上证ID
    - sz399001 #  深证ID
  outer: # 外盘
    - int_dji # 道琼斯
    - int_nasdaq # 纳斯达克
    - int_hangseng # 恒生
    - int_nikkei # 日经指数
    - b_FSSTI # 新加坡

 2.写一个与yml相互映射的类来读取yml的属性信息

注意:属性名字必须与yml文件中的属性一致

在这个类中我们没有把它交给Spring管理,即还没有进行加载,没有映射

@Data
@ConfigurationProperties(prefix = "stock")//映射yml文件中stock属性的值
//@Component//直接让其交给spring管理,TODO:我们不使用(不让它自己开启),我们让其他要使用该类的子模块来开启
public class StockInfoConfig {
    public List<String>inner;//国内大盘编码
   public List<String>outer;//国外大盘编码
}

3.在其他子模块的配置类中开启此类,读取yml文件的内容信息

使用@EnableConfigurationProperties,让这个子模块开启加载此配置类,并让它映射yml文件中的stock属性的值,再交给spring管理

@Configuration
@EnableConfigurationProperties(StockInfoConfig.class)//TODO:在这个子模块开启加载此配置类,并让它映射yml文件中的stock属性的值,再交给spring管理
public class CommonConfig {
}

4.直接依赖注入(因为已经交给spring管理),再使用 List<String> mcodes = stockInfoConfig.getInner();

@Service
@Slf4j
public class StockServiceImpl implements StockService {
    @Autowired
    private StockInfoConfig stockInfoConfig;
    @Autowired
    private StockMarketIndexInfoMapper stockMarketIndexInfoMapper;

    @Override
    public R<List<InnerMarketDomain>> getInnerMarket() {
        //1.获取当前时间的最新交易点(精确到分钟,秒和毫秒置为0)
        //Date curDate = DateTimeUtil.getLastDate4Stock(DateTime.now()).toDate();
        Date curDate = MyDateTimeUtil.getLateDate4Stock(DateTime.now()).toDate();

        //mock data 等后续股票采集job工程完成,再将此代码删除
        //curDate=DateTime.parse("2021-12-28 09:31:00", DateTimeFormat.forPattern("yyyy-MM-dd HH:mm:ss")).toDate();
        //log.info("curDate:{}",curDate);
        //2.获取国内大盘的编码集合
        List<String> mcodes = stockInfoConfig.getInner();
        //3.调用mapper进行查询
        List<InnerMarketDomain> data=stockMarketIndexInfoMapper.getInnerMarket(curDate,mcodes);
        //4.返回数据
        return R.ok(data);
    }
}
List<InnerMarketDomain> getInnerMarket(@Param("curDate") Date curDate, @Param("marketCodes") List<String> marketCodes);
 <select id="getBlock4Ten" resultType="com.hhh.stock.pojo.domain.BlockDomain">
        select company_num as companyNum,
               trade_amount as tradeAmt,
               label as code,
               avg_price as avgPrice,
               block_name as name,
               cur_time as curDate,
               trade_volume as tradeVol,
               updown_rate as updownRate
        from stock_block_rt_info
        where cur_time=#{curDate}
        order by trade_volume desc limit 10;
    </select>

cur_time是datetime类型,curDate是Date类型,datetime类型可以直接和Date类型进行比较,datetime查询出来的数据类型也是Date,但是Date数据类型要存入数据库时,必须设置成指定时间格式的string类型进行存入数据库

@Data
@ApiModel(description = "大盘数据")
public class InnerMarketDomain {
    @ApiModelProperty("大盘编码")
    private String code;//大盘编码
    @ApiModelProperty("指数名称")
    private String name;//指数名称
    @ApiModelProperty("开盘点")
    private BigDecimal openPoint;//开盘点
    @ApiModelProperty("当前点")
    private BigDecimal curPoint;//当前点
    @ApiModelProperty("前收盘点")
    private BigDecimal preClosePoint;//前收盘点
    @ApiModelProperty("交易量")
    private Long tradeAmt;//交易量
    @ApiModelProperty("交易金额")
    private Long tradeVol;//交易金额
    @ApiModelProperty("涨跌值")
    private BigDecimal upDown;//涨跌值
    @ApiModelProperty("涨幅")
    private BigDecimal rose;//涨幅
    @ApiModelProperty("振幅")
    private BigDecimal amplitude;//振幅
    @ApiModelProperty("当前时间")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm")//设置返回前端的时间格式
    private Date curTime;//当前时间
}

 

结果:
 

直接推送git

 git push origin master --force

实体对象说明

 

1.pojo

java普通对象,范围比较大,本质上就是一个数据容器,且无需提供复杂的方法(只需有get set方法)

2.domain

领域对象,就是将某个业务方向的数据加以封装成的对象,比如:以数据库为例子,该类的数据可能来自多张表的字段,或者单张表的某系字段

3.entity

与数据库表字段一一对应的实体对象

4.vo-->value object对象

就是保存值的对象,内置的属性是与yml文件相互映射保存数据的(使用@ConfigurationProperties),等到要使用的时候直接使用@EnableConfigurationProperties注解来开始让使用了@ConfigurationProperties注解的类映射yml文件属性内容,然后交给spring管理。

5.vo-->view object对象

就是与前端交互的数据对象

注意:domian包下的类是直接与数据库交互直接进行赋值,而view object是与前端进行交互的,通过domain或者entity进行赋值

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2086659.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

金九银十跳槽季,最新自动化测试面试题合集

前言 Hello,大家好。金九银十也不远了&#xff0c;有的人盼望升职加薪&#xff0c;有的人立了新的Flag&#xff0c;有跳槽计划的该提上日程了。为解大伙的燃眉之急&#xff0c;今天分享自动化面试题预热一波&#xff0c;欢迎留言区补充评论&#xff01; 一、请描述一下自动化测…

sqli-labs靶场通关攻略(四十一到五十关)

sqli-labs-master靶场第四十一关 一&#xff0c;查看数据库 ?id-1 union select 1,2,database()-- 二&#xff0c;查看表名 ?id-1 union select 1,group_concat(table_name),3 from information_schema.tables where table_schemadatabase()-- 三&#xff0c;查看users表中…

python学习之路 - python对mysql的数据操作

目录 一、python对mysql的数据操作1、前期准备2、连接mysql3、创建表5、插入表4、查询表 一、python对mysql的数据操作 1、前期准备 使用python对mysql进行相关操作前&#xff0c;需要安装pymysql。执行pip install pymysql命令即可如果具体不知道如何操作&#xff0c;可以查…

导入pyBigWig包

今天复现论文时&#xff0c;看到了一种叫做bigwig格式的数据&#xff0c;创建和访问该格式文件需要用到pybigwig包&#xff0c;在此过程中遇到了一些问题&#xff0c;记录一下。 介绍 pybigwig的使用依赖于两个C库&#xff0c;所谓C库就是C语言编写的python库。 正如在pypi官…

聚类算法-DBSCAN

文章目录 一、DBSCAN介绍1.含义2.DBSCAN 的核心概念3.DBSCAN算法参数 二、代码实现1.数据预处理2.DBSCAN聚类3.计算轮廓系数4.全部代码 三、总结 一、DBSCAN介绍 1.含义 DBSCAN&#xff08;Density-Based Spatial Clustering of Applications with Noise&#xff09;是一种基…

llama-cpp-python编译失败,解决方案安装wheel文件

https://abetlen.github.io/llama-cpp-python/whl/cu121/llama-cpp-python/编译失败&#xff1a; 解决方案&#xff1a;使用轮子镜像

Clion/Vs中wcout输出中文不显示的解决办法

本来要写个输出所有窗口的代码&#xff0c;但是结果文字一直不输出&#xff0c;又试了试发现只是汉字不输出&#xff1a; #include <windows.h> #include <iostream> #include <vector> #include <string>std::vector<std::wstring> windowTitl…

数据结构(6.4_4)——Floyd算法

Floyd算法 第一步&#xff1a;建立两个二维数组&#xff0c;一个用来存放所有顶点&#xff0c;一个用来存放顶点之间的中转点 第二步&#xff1a;循环遍历A矩阵&#xff0c;若,则&#xff0c;&#xff1b;否则 和保持原值&#xff0c;循环完所有i&#xff0c;j后更新数组并且…

材料表面缺陷检测系统源码分享 # [一条龙教学YOLOV8标注好的数据集一键训练_70+全套改进创新点发刊_Web前端展示]

材料表面缺陷检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer Vis…

【rk3588】环境搭建及系统编译

开发板&#xff1a;ROC-RK3588S-PC 官方链接&#xff1a;Welcome to ROC-RK3588S-PC Manual — Firefly Wiki (t-firefly.com) 串口调试配置 一、产品介绍 — Firefly Wiki (t-firefly.com)&#xff0c;可以按照官方链接的说明在个人PC上使用串口。这个串口会输出rk3588的日…

字典查找对应输入的字符

一、将文件放入到数据库 #include<stdio.h> #include<sqlite3.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <string.h> #include <unistd.h> int main(int agrc,char *agrv[]) {FILE *fp;fp fope…

详细介绍校园网络拓扑结构设计图

目录 需求分析 网络架构设计 拓扑图设计 安全策略 出口设计 总结 校园网络拓扑结构设计是一种对学校内计算机、网络设备和软件进行集成应用的系统化设计&#xff0c;旨在为师生提供一个高效、稳定、安全的网络平台&#xff0c;以支持教学、科研和管理的信息化需求。一个优…

RKNPU2从入门到实践 ---- 【8】借助 RKNN Toolkit lite2 在RK3588开发板上部署RKNN模型

前言 作者使用的平台为Ubuntu20.04虚拟系统&#xff0c;开发板为瑞芯微RK3588&#xff0c;开发板上的系统为Ubuntu22.04系统。 一、任务 完成RKNN模型的部署&#xff0c;RKNN模型的部署是将RKNN模型放到开发板上&#xff0c;应用程序可以加载RKNN模型&#xff0c;从而在嵌入式…

进阶SpringBoot之 Shiro(1)快速开始

Shiro 是一个 Java 的安全&#xff08;权限&#xff09;框架&#xff0c;它可以在 JavaSE、JavaEE 环境下使用 Shiro 可以实现认证、授权、加密、会话管理、Web 集成、缓存等 Shiro 官网 Shiro 中文文档 GitHub 下载 Shiro 下载源码&#xff0c;samples -> quickstart …

Linux-全网备份实战案例rsync邮件发送

项目准备 服务端&#xff1a;backup&#xff1a;172.16.1.41 客户端1&#xff1a;nfs:172.16.1.31 客户端2&#xff1a; web01:172.16.1.7 1.1 服务端backup-rsync配置文件 [rootbackup ~]# cat /etc/rsyncd.conf #created by linux 2024-8-29 ###########rsyncd.conf star…

进程和线程(操作系统八股文part2)

一个操作系统的进程和线程部分的笔记&#xff0c;大部分来源于&#xff1a;小林coding和Javaguide&#xff0c;以及操作系统黑书。 进程和线程 什么是进程 运行中的程序叫进程**&#xff08;Process&#xff09;**。 进程是资源分配的最小单位&#xff0c;线程是执行的最小…

【逐行注释】MATLAB下的UKF(无迹卡尔曼滤波),带丰富的中文注释,可直接复制到MATLAB上运行,无需下载

文章目录 程序组成部分完整代码运行结果主要模块解读:运动模型绘图部分误差统计特性输出程序组成部分 由模型初始化、运动模型、UKF主体部分、绘图代码和输出部分组成: 完整代码 将下列代码复制粘贴到MATLAB里面,即可运行: % 三维状态量的UKF例程 % 作者联系方式:微信…

学苑教育杂志社学苑教育编辑部学苑教育杂志2024年第23期目录

专题研究 “三全六为”教育教学理念的实践运用 果艳青; 4-6 教育管理 班主任班级管理工作中进行小组合作的优化策略 肖堂花; 7-9 课堂教学 以“创新”为支点&#xff0c;构建小学数学活力课堂 马绪如; 10-12 案例教学法在初中道德与法治教学中的应用 何瑞娟; 1…

js实现队列

目录 一、什么是JavaScript队列数据结构二、创建一个JavaScript队列数据结构三、封装队列方法①向队列添加元素②检查队列是否为空③获取队列的长度④从队列移除元素⑤查看队列头元素⑥清空队列⑦创建toString方法 四、使用Queue类 一、什么是JavaScript队列数据结构 在上一篇…

【解析几何笔记】11.向量的外积运算

11. 向量的外积运算 【注】也可以这么计算 11.1 向量的多重乘积 【命题】任意三个向量&#xff0c; α , β , γ \pmb{\alpha},\pmb{\beta},\pmb{\gamma} α,β,γ&#xff0c; ( α β ) γ ( α ⋅ γ ) β − ( β ⋅ γ ) α (\pmb{\alpha}\times\pmb{\beta})\times\p…