数据模拟:利用Java模拟数据(姓名,邮箱,地址,电话等信息,时间,工资,1-10随机数)并存入mysql

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 数据模拟:利用Java模拟数据(姓名,邮箱,地址,电话等信息,时间,工资,1-10随机数)并存入mysql
学大数据分析的同学们在做数据分析时一般很难找到适合数据集,本文就来分享一下如何利用Java模拟数据,并将产生数据保存至mysql数据库中。
主要技术就是Java产生数据,利用mybatis存入mysql数据库

1.数据库建表

模拟之前需要建表:也就是说你要模拟什么数据就建对应的表
本次模拟的数据是教师相关信息

建数据库teacher,建表teacher

可以利用第三方工具也可以,通过执行sql
在这里插入图片描述

sql:

CREATE DATABASE /*!32312 IF NOT EXISTS*/`teacher` /*!40100 DEFAULT CHARACTER SET utf8 */ /*!80016 DEFAULT ENCRYPTION='N' */;

USE `teacher`;

/*Table structure for table `teacher` */

DROP TABLE IF EXISTS `teacher`;

CREATE TABLE `teacher` (
  `id` int unsigned NOT NULL AUTO_INCREMENT COMMENT '教师编号',
  `name` varchar(255) DEFAULT NULL COMMENT '教师姓名',
  `phone` varchar(255) DEFAULT NULL COMMENT '教师手机号',
  `email` varchar(255) DEFAULT NULL COMMENT '电子邮件',
  `address` varchar(255) DEFAULT NULL COMMENT '家庭地址',
  `time` varchar(255) DEFAULT NULL COMMENT '时间',
  `salary` varchar(255) DEFAULT NULL COMMENT '工资',
  `random` int DEFAULT NULL COMMENT '随机生成1-10的数',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb3;

2.构建maven项目

打开idea建一个maven项目,项目名随便命名
结构如下:

在这里插入图片描述

导入依赖:pom文件如下

<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.example</groupId>
    <artifactId>Data</artifactId>
    <version>1.0-SNAPSHOT</version>
    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13.1</version>
            <scope>test</scope>
        </dependency>
        <!-- Mybatis核心 -->
        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.10</version>
        </dependency>
        <!-- MySQL驱动 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.29</version>
        </dependency>
    </dependencies>

    <properties>
        <maven.compiler.source>8</maven.compiler.source>
        <maven.compiler.target>8</maven.compiler.target>
    </properties>

</project>

3.项目结构

结构图示:
在这里插入图片描述

ming.txt

冠钧 子阳 晨君 泓铭 琦霖 诗雨 语桐 奕骁 子鑫 宗鑫 政尚 桐畅 楷瑞 栩安 伟桐 栩昊 璟弘 羽洋 翊宁 锡麟 以钦 俊皓 允泽 南柔 启元 德凯 振烨 梓硕 璟文 翊涛 承烨 钰睿 宇轩 宸源 朝义 一桐 亦程 君睿 启鑫 小西 昱硕 梓熙 歆焱 洛颜 熙宸 瑜文 鑫龙 颢程 亦泽 俊伟 俊宁 俊希 健慧 吉洋 咏腾 嘉翔 奕然 家翊 家茗 小祺 少博 恩康 承允 文乐 易瑞 景潇 松睿 林枫 楚天 沐灵 泽豪 浩淼 清楚 瀚宇 玖辰 睿涵 睿熙 维宁 誉喆 诺迪 贤俊 轩彬 轩昂 逸楠 逸铭 金淼 锡梵 锦凡 靖翔 骏琪 鸣钥 鹏宇 一航 语鑫 铭誉 麒瑞 晗君 楷翔 嘉豪

xing.txt

赵 钱 孙 李 周 吴 郑 王 冯 陈 褚 卫 蒋 沈 韩 杨 朱 秦 尤 许 何 吕 施 张 孔 曹 严 华 金 魏 陶 姜 戚 谢 邹 喻 柏 水 窦 章 云 苏 潘 葛 奚 范 彭 郎 鲁 韦 昌 马 苗 凤 花 方 俞 任 袁 柳 酆 鲍 史 唐 费 廉 岑 薛 雷 贺 倪 汤 滕 殷 罗 毕 郝 邬 安 常 乐 于 时 傅 皮 卞 齐 康 伍 余 元 卜 顾 孟 平 黄 和 萧 尹 湛 汪 祁 毛 禹 狄 米 贝 成 戴 谈 宋 茅 庞 熊 纪 舒 屈 项 祝 董 梁 杜 阮 蓝 闵 席 季 麻 强 贾 路 娄 危 江 童 颜 郭 梅 盛 林 刁 钟 徐 邱 骆 高 夏 蔡 田 樊 胡 凌 霍 虞 万 支 柯 昝 管 卢 莫 白 房 裘 缪 干 解 应 宗 丁 宣 贲 邓 郁 单 杭 洪 包 诸 左 石 崔 吉 钮 龚 程 嵇 邢 滑 裴 陆 荣 翁 荀 羊

mybatis-config.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <!--设置连接数据库的环境-->
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"/>
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/teacher?characterEncoding=utf8"/>
                <property name="username" value="root"/>
                <property name="password" value="021806"/>
            </dataSource>
        </environment>
    </environments>
    <!--引入映射文件-->
    <mappers>
        <mapper resource="mappers/TeacherMapper.xml"/>
    </mappers>
</configuration>
这里要注意mysql密码改成自己的

4.编写实体类和工具类

实体类与mysql数据库中的表对应
工具类是用于模拟生成数据的

a.实体类

package com.li.pojo;

public class Teacher {
    private int uid;
    private String name;
    private String phone;
    private String email;
    private String address;
    private String time;
    private String salary;
    private int random;

    public Teacher() {
    }

    public int getUid() {
        return uid;
    }

    public void setUid(int uid) {
        this.uid = uid;
    }

    public String getName() {
        return name;
    }

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

    public String getPhone() {
        return phone;
    }

    public void setPhone(String phone) {
        this.phone = phone;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    public String getAddress() {
        return address;
    }

    public void setAddress(String address) {
        this.address = address;
    }

    public String getTime() {
        return time;
    }

    public void setTime(String time) {
        this.time = time;
    }

    public String getSalary() {
        return salary;
    }

    public void setSalary(String salary) {
        this.salary = salary;
    }

    public int getRandom() {
        return random;
    }

    public void setRandom(int random) {
        this.random = random;
    }

    @Override
    public String toString() {
        return "Teacher{" +
                "uid=" + uid +
                ", name='" + name + '\'' +
                ", phone='" + phone + '\'' +
                ", email='" + email + '\'' +
                ", address='" + address + '\'' +
                ", time='" + time + '\'' +
                ", salary='" + salary + '\'' +
                ", random=" + random +
                '}';
    }

    public Teacher(int uid, String name, String phone, String email, String address, String time, String salary, int random) {
        this.uid = uid;
        this.name = name;
        this.phone = phone;
        this.email = email;
        this.address = address;
        this.time = time;
        this.salary = salary;
        this.random = random;
    }
}

b.随机生成地址

package com.li.Utils;

import java.util.Random;

public class AdressUtils {
    public static String getProCity(){

        String[] province = {"河北省","山西省","辽宁省","吉林省","黑龙江","江苏省","浙江省","安徽省","福建省","江西省","山东省","河南省","湖北省","湖南省","广东省","海南省","四川省","贵州省","云南省","陕西省","甘肃省","青海省","台湾省","北京市","天津市","广西省","内蒙古","宁夏省","新疆省","上海市","香港区","澳门区","重庆市","西藏市",};
        String[] city = {"安康市","安庆市","安顺市","安阳市","鞍山市","巴彦淖尔市","巴中市","白城市","白山市","白银市","百色市","蚌埠市","包头市","宝鸡市","保定市","保山市","北海市","本溪市","滨州市","沧州市","昌都地区","长春市","长沙市","长治市","常德市","常州市","巢湖市","朝阳市","潮州市","郴州市","成都市","承德市","池州市","赤峰市","崇左市","滁州市","达州市","大连市","大庆市","大同市","丹东市","德阳市","德州市","定西市","东莞市","东营市","鄂尔多斯市","鄂州市","防城港市","佛山市","福州市","抚顺市","抚州市","阜新市","阜阳市","甘南州","赣州市","固原市","广安市","广元市","广州市","贵港市","贵阳市","桂林市","哈尔滨市","哈密地区","海北藏族自治州","海东地区","海口市","邯郸市","汉中市","杭州市","毫州市","合肥市","河池市","河源市","菏泽市","贺州市","鹤壁市","鹤岗市","黑河市","衡水市","衡阳市","呼和浩特市","呼伦贝尔市","湖州市","葫芦岛市","怀化市","淮安市","淮北市","淮南市","黄冈市","黄山市","黄石市","惠州市","鸡西市","吉安市","吉林市","济南市","济宁市","佳木斯市","嘉兴市","嘉峪关市","江门市","焦作市","揭阳市","金昌市","金华市","锦州市","晋城市","晋中市","荆门市","荆州市","景德镇市","九江市","酒泉市","开封市","克拉玛依市","昆明市","拉萨市","来宾市","莱芜市","兰州市","廊坊市","乐山市","丽江市","丽水市","连云港市","辽阳市","辽源市","聊城市","临沧市","临汾市","临沂市","柳州市","六安市","六盘水市","龙岩市","陇南市","娄底市","泸州市","吕梁市","洛阳市","漯河市","马鞍山市","茂名市","眉山市","梅州市","绵阳市","牡丹江市","内江市","南昌市","南充市","南京市","南宁市","南平市","南通市","南阳市","宁波市","宁德市","攀枝花市","盘锦市","平顶山市","平凉市","萍乡市","莆田市","濮阳市","普洱市","七台河市","齐齐哈尔市","钦州市","秦皇岛市","青岛市","清远市","庆阳市","曲靖市","衢州市","泉州市","日照市","三门峡市","三明市","三亚市","汕头市","汕尾市","商洛市","商丘市","上饶市","韶关市","邵阳市","绍兴市","深圳市","沈阳市","十堰市","石家庄市","石嘴山市","双鸭山市","朔州市","四平市","松原市","苏州市","宿迁市","宿州市","绥化市","随州市","遂宁市","台州市","太原市","泰安市","泰州市","唐山市","天水市","铁岭市","通化市","通辽市","铜川市","铜陵市","铜仁市","吐鲁番地区","威海市","潍坊市","渭南市","温州市","乌海市","乌兰察布市","乌鲁木齐市","无锡市","吴忠市","芜湖市","梧州市","武汉市","武威市","西安市","西宁市","锡林郭勒盟","厦门市","咸宁市","咸阳市","湘潭市","襄樊市","孝感市","忻州市","新乡市","新余市","信阳市","兴安盟","邢台市","徐州市","许昌市","宣城市","雅安市","烟台市","延安市","盐城市","扬州市","阳江市","阳泉市","伊春市","伊犁哈萨克自治州","宜宾市","宜昌市","宜春市","益阳市","银川市","鹰潭市","营口市","永州市","榆林市","玉林市","玉溪市","岳阳市","云浮市","运城市","枣庄市","湛江市","张家界市","张家口市","张掖市","漳州市","昭通市","肇庆市","镇江市","郑州市","中山市","中卫市","舟山市","周口市","株洲市","珠海市","驻马店市","资阳市","淄博市","自贡市","遵义市",};
        String[] area = {"伊春区","带岭区","南岔区","金山屯区","西林区","美溪区","乌马河区","翠峦区","友好区","新青区","上甘岭区","五营区","红星区","汤旺河区","乌伊岭区","榆次区"};
        String[] road = {"爱国路","安边路","安波路","安德路","安汾路","安福路","安国路","安化路","安澜路","安龙路","安仁路","安顺路","安亭路","安图路","安业路","安义路","安远路","鞍山路","鞍山支路","澳门路","八一路","巴林路","白城路","白城南路","白渡路","白渡桥","白兰路","白水路","白玉路","百安路(方泰镇)","百官街","百花街","百色路","板泉路","半淞园路","包头路","包头南路","宝安公路","宝安路","宝昌路","宝联路","宝林路","宝祁路","宝山路","宝通路","宝杨路","宝源路","保德路","保定路","保屯路","保屯路","北艾路",};
        String[] home = {"金色家园","耀江花园","阳光翠竹苑","东新大厦","溢盈河畔别墅","真新六街坊","和亭佳苑","协通公寓","博泰新苑","菊园五街坊","住友嘉馨名园","复华城市花园","爱里舍花园"};
        Random random = new Random();
        int randomProvinceNum = random.nextInt(province.length);
        int randomCityNum = random.nextInt(city.length);
        int randomAreaNum = random.nextInt(area.length);
        int randomRoadNum = random.nextInt(road.length);
        int randomHomeNum = random.nextInt(home.length);
        int num = random.nextInt(200);
        return province[randomProvinceNum]+city[randomAreaNum]+area[randomAreaNum]+road[randomRoadNum]+num+"号"+home[randomHomeNum];
    }

}

c.随机生成姓名

package com.li.Utils;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.InputStreamReader;
import java.util.Random;

public class NameUtils {
    public static String GetName(){
        String name = getXing().concat(getMing());
        return name;
    }
    // 从数据中 获取名字
    public static String getMing(){
        String ming = readFile("D:\\JavaProject\\Data\\src\\main\\java\\com\\li\\data\\ming.txt");
//        System.out.println(ming);
        String[] mings = ming.split(" ");
        Random rd = new Random();
        String mm = mings[rd.nextInt(mings.length)];
        return mm;
    }
    // 从百家姓中 获取一个  姓
    public static String getXing(){
        String xx = readFile("D:\\JavaProject\\Data\\src\\main\\java\\com\\li\\data\\xing.txt");
//        System.out.println(xx);
        String[] xings = xx.split(" ");
        Random rd = new Random();
        String x = xings[rd.nextInt(xings.length)];
        return x;
    }
    // 读取文档中的内容,一行一行读取的
    public static String readFile(String path){
        File file = new File(path);
        StringBuilder result = new StringBuilder();
        try {
            BufferedReader br = new BufferedReader(new InputStreamReader(new FileInputStream(file),"UTF-8"));
            String s = null;
            while ((s=br.readLine())!=null){
                result.append(System.lineSeparator()+s);
            }
            br.close();
        }catch (Exception e){
            System.err.println("获取文件失败!!!");
        }
        return result.toString();
    }
}

d.随机生成电子邮件

package com.li.Utils;

import java.util.Random;

public class EmailUtils {
    public static String GetEmail(){
        String email = getTel().concat(getCom());
        return email;

    }
    public static String getCom(){
        String[] year = {"@qq.com","@163.com","@yahoo.cn","@sina.com","@gmail.com",};
        Random random = new Random();
        int year1 = random.nextInt(year.length);
        return "."+year[year1];

    }
    public static String getTel(){
        Random rd = new Random();
        String tel;
        String[] num1 = {"2","4","6","8"};
        String[] num2 = {"1","3","5","7"};
        tel = num1[rd.nextInt(4)] + num2[rd.nextInt(4)];

        for (int i=0;i<5;i++){
            int num = rd.nextInt(10);
            tel = tel + num;
        }
        return tel;
    }
}

e.随机生成电话号码

package com.li.Utils;

import java.util.Random;

public class PhoneUtils {
    //    IP、状态码、 性别
    // 随机生成手机号11位   1 [3,5,7,8]   0-9
    public static String getTel(){
        Random rd = new Random();
        String tel = "1";
        String[] num2 = {"3","5","7","8"};
        tel = tel + num2[rd.nextInt(4)];

        for (int i=0;i<9;i++){
            int num = rd.nextInt(10);
            tel = tel + num;
        }
        return tel;
    }
}

f.随机生成日期

package com.li.Utils;

import java.util.Random;

public class TimeUtils {
    public static String Time(){

        String[] year = {"2016","2017","2018","2019","2020","2021","2022",};
        String[] mounth = {"01","02","03","04","05","06","07","08","09","10","11","12",};
        String[] day = {"01","02","03","04","05","06","07","08","09","10","11","12","13","14","15","16","17","18","19","20","21","22","23","24","25","26","27","28","29","30",};
        Random random = new Random();
        int year1 = random.nextInt(year.length);
        int mounth1 = random.nextInt(mounth.length);
        int day1 = random.nextInt(day.length);
        return year[year1]+"-"+mounth[mounth1]+"-"+day[day1];
    }
}

g.生成工资

package com.li.Utils;

import java.util.Random;

public class SalaryUtils {
    public static String getSalary(){
        String[] salary = {"4500","6500","8000","10000","12000","18000","20000",};
        Random random = new Random();
        int salary1 = random.nextInt(salary.length);
        return salary[salary1]+"元";
    }
}

h.生成1-10随机数

package com.li.Utils;

import java.util.Random;

public class NumUtils {
    public static int Num(){
        Random random = new Random();
        int a = random.nextInt(10)+1;
        return a;
    }
}

i.获取sqlSession工具类

package com.li.Utils;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;

import java.io.IOException;
import java.io.InputStream;

public class GetSqlSession {
    public static SqlSession getSqlSession(){
        try {
            InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
            SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
            SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(is);
            //4.mybatis-config.xml
            SqlSession sqlSession = sqlSessionFactory.openSession(true);
            return sqlSession;
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }
}

5.生成数据并插入mysql数据库

a.TeacherMapper接口

package com.li.mapper;

import com.li.pojo.Teacher;

public interface TeacherMapper {

    int insertTeacher(Teacher teacher);
    int add();


}

b.TeacherMapper.xml

这里id自增
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--insert into teacher values (#{name},#{phone},#{email},#{age},#{offer},#{address},#{status},#{time},#{salary})-->
<mapper namespace="com.li.mapper.TeacherMapper">
    <insert id="insertTeacher" parameterType="com.li.pojo.Teacher">
        insert into teacher (id ,name ,phone,email,address,time,salary,random) 
        values (null ,#{name},#{phone},#{email},#{address},#{time},#{salary},#{random})
    </insert>
</mapper>

c.test 类实现生成并插入

通过for循环来指定生成数据的数量
package com.li;

import com.li.Utils.*;
import com.li.mapper.TeacherMapper;
import com.li.pojo.Teacher;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;

import java.util.Random;

public class test {
    @Test
    public void insertTest(){
        for (int i=0;i<20;i++){
            Teacher teacher = new Teacher();
            teacher.setName(NameUtils.GetName());
            teacher.setPhone(PhoneUtils.getTel());
            teacher.setEmail(EmailUtils.GetEmail());
            teacher.setAddress(AdressUtils.getProCity());
            teacher.setTime(TimeUtils.Time());
            teacher.setSalary(SalaryUtils.getSalary());
            teacher.setRandom(NumUtils.Num());
            SqlSession sqlSession = GetSqlSession.getSqlSession();
            TeacherMapper mapper = sqlSession.getMapper(TeacherMapper.class);
            System.out.println(i);
            int a = mapper.insertTeacher(teacher);
        }

    }
}

查看数据库

在这里插入图片描述

6.写在最后

数据都是模拟产生的,数据不是很准确,但是可以做为练习,想生成其它数据可以把这个作为模板来改进!
项目也有很多改进的地方,比如日期,地址,也可以改成类似与生成姓名那种形式,这样就可以避免地址重复,时间不准确
也可以当作一个Java小项目练习。
项目源码地址:
大家可以下载并改正!
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
20天前
|
存储 关系型数据库 MySQL
mysql怎么查询longblob类型数据的大小
通过本文的介绍,希望您能深入理解如何查询MySQL中 `LONG BLOB`类型数据的大小,并结合优化技术提升查询性能,以满足实际业务需求。
79 6
|
2月前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
本文介绍了MySQL InnoDB存储引擎中的数据文件和重做日志文件。数据文件包括`.ibd`和`ibdata`文件,用于存放InnoDB数据和索引。重做日志文件(redo log)确保数据的可靠性和事务的持久性,其大小和路径可由相关参数配置。文章还提供了视频讲解和示例代码。
156 11
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
|
2月前
|
SQL Java
使用java在未知表字段情况下通过sql查询信息
使用java在未知表字段情况下通过sql查询信息
39 8
|
1月前
|
SQL 关系型数据库 MySQL
mysql分页读取数据重复问题
在服务端开发中,与MySQL数据库进行数据交互时,常因数据量大、网络延迟等因素需分页读取数据。文章介绍了使用`limit`和`offset`参数实现分页的方法,并针对分页过程中可能出现的数据重复问题进行了详细分析,提出了利用时间戳或确保排序规则绝对性等解决方案。
|
2月前
|
关系型数据库 MySQL 数据库
GBase 数据库如何像MYSQL一样存放多行数据
GBase 数据库如何像MYSQL一样存放多行数据
|
2月前
|
缓存 NoSQL 关系型数据库
Redis和Mysql如何保证数据⼀致?
在项目中,为了解决Redis与Mysql的数据一致性问题,我们采用了多种策略:对于低一致性要求的数据,不做特别处理;时效性数据通过设置缓存过期时间来减少不一致风险;高一致性但时效性要求不高的数据,利用MQ异步同步确保最终一致性;而对一致性和时效性都有高要求的数据,则采用分布式事务(如Seata TCC模式)来保障。
73 14
|
2月前
|
SQL 前端开发 关系型数据库
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
68 9
|
2月前
|
人工智能 监控 数据可视化
Java智慧工地信息管理平台源码 智慧工地信息化解决方案SaaS源码 支持二次开发
智慧工地系统是依托物联网、互联网、AI、可视化建立的大数据管理平台,是一种全新的管理模式,能够实现劳务管理、安全施工、绿色施工的智能化和互联网化。围绕施工现场管理的人、机、料、法、环五大维度,以及施工过程管理的进度、质量、安全三大体系为基础应用,实现全面高效的工程管理需求,满足工地多角色、多视角的有效监管,实现工程建设管理的降本增效,为监管平台提供数据支撑。
50 3
|
安全 Java
Java生成随机数的4种方式,以后就用它了!(8)
Java生成随机数的4种方式,以后就用它了!(8)
249 0
Java生成随机数的4种方式,以后就用它了!(8)
|
算法 Java
Java生成随机数的4种方式,以后就用它了!(7)
Java生成随机数的4种方式,以后就用它了!(7)
410 0
Java生成随机数的4种方式,以后就用它了!(7)