通义千问AI+Java

2024-06-20 00:12
文章标签 java ai 通义 千问

本文主要是介绍通义千问AI+Java,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

如何提问

Prompt的组成

  • 角色:给 AI 定义一个最匹配任务的角色,比如:「你是一位软件工程师」「你是一位小学老师」
  • 指示:对任务进行描述
  • 上下文:给出与任务相关的其它背景信息(尤其在多轮交互中)
  • 例子:必要时给出举例,[实践证明其对输出正确性有帮助]
  • 输入:任务的输入信息;在提示词中明确的标识出输入
  • 输出:输出的格式描述,以便后继模块自动解析模型的输出结果,比如(JSON、Java)

先定义角色,其实就是在开头把问题域收窄,减少二义性。

案例:

角色:你是一位专业的博客作者。指示:撰写一篇关于最新AI技术发展的文章。上下文:文章应该涵盖AI技术的当前状态和未来趋势。例子:可以引用最近的AI技术突破和行业专家的见解。输入:当前AI技术的相关信息和数据。输出:一篇结构清晰、观点鲜明的文章草稿。
角色:你是一位资深的Java开发工程师。指示:编写一个Java函数,该函数接收两个整数参数,并返回它们的和。上下文:这个函数将被用于一个简单的数学应用程序,该程序帮助学生练习基本的算术运算。例子:如果你调用函数 `addNumbers(3, 5)`,它应该返回 `8`。输入:两个整数参数,分别为 `int a` 和 `int b`。输出:返回这两个整数的和,类型为 `int`。

生成表结构

你是一个软件工程师,帮我生成MySQL的表结构
需求如下:1,课程管理表,表名tb_course,字段有主键id、课程编码、课程学科、课程名称、课程价格、适用人群、课程介绍
其他要求:1,每个表中都有创建时间(create_time)、修改时间(date_time)、创建人(create_by)、修改人(update_by)、备注(remark)这些字段2,每个表的主键都是自增的3,课程价格是整型、课程编码是字符串4,请为每个字段都添加上comment5,帮我给生成的表中插入一些IT课程示例数据课程学科:Java、人工智能、大数据适用人群:小白学员、中级程序员

回答

基于您的需求,以下是创建tb_course表的SQL语句,包含了指定的字段、约束条件以及注释,并且我会为您插入一些示例数据:

CREATE TABLE `tb_course` (`id` INT AUTO_INCREMENT PRIMARY KEY COMMENT '主键ID',`course_code` VARCHAR(50) NOT NULL COMMENT '课程编码',`subject` VARCHAR(100) NOT NULL COMMENT '课程学科',`course_name` VARCHAR(255) NOT NULL COMMENT '课程名称',`course_price` INT NOT NULL COMMENT '课程价格(单位:元)',`target_audience` VARCHAR(100) NOT NULL COMMENT '适用人群',`course_introduction` TEXT COMMENT '课程介绍',`create_time` DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',`update_time` DATETIME ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间',`create_by` VARCHAR(50) COMMENT '创建人',`update_by` VARCHAR(50) COMMENT '修改人',`remark` VARCHAR(255) COMMENT '备注'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='课程管理表';-- 插入示例数据
INSERT INTO `tb_course`(`course_code`, `subject`, `course_name`, `course_price`, `target_audience`, `course_introduction`)
VALUES 
('JAVA001', 'Java', 'Java基础入门', 99, '小白学员', '本课程适合编程零基础,想要学习Java语言的小白学员'),
('AI101', '人工智能', '机器学习实战', 199, '中级程序员', '本课程适合有一定编程基础,想深入了解机器学习的中级程序员'),
('BIGDATA202', '大数据', 'Hadoop大数据处理', 299, '中级程序员', '面向中级程序员,全面讲解Hadoop生态系统及其在大数据处理中的应用');

这段SQL首先定义了tb_course表结构,包括您提到的所有字段,并对每个字段添加了注释。同时,它设置了主键自动增长,并为创建时间和修改时间设定了默认值和更新规则。最后,我插入了三条示例记录,分别代表Java、人工智能、大数据领域的课程,每条记录都指明了适用的人群和简要的课程介绍。


生成数据库说明文档

你是一个软件工程师,现在要根据数据库的sql脚本,编写数据库说明文档,sql脚本如下:
CREATE TABLE `tb_course` (`id` INT AUTO_INCREMENT COMMENT '主键ID',`course_code` VARCHAR(255) NOT NULL COMMENT '课程编码',`course_subject` VARCHAR(100) NOT NULL COMMENT '课程学科',`course_name` VARCHAR(255) NOT NULL COMMENT '课程名称',`course_price` INT COMMENT '课程价格',`target_audience` VARCHAR(100) COMMENT '适用人群',`course_introduction` TEXT COMMENT '课程介绍',`create_time` DATETIME COMMENT '创建时间',`update_time` DATETIME COMMENT '修改时间',`create_by` VARCHAR(64) COMMENT '创建人',`update_by` VARCHAR(64) COMMENT '修改人',`remark` VARCHAR(255) COMMENT '备注',PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='课程管理表';输出要求是:1,每个表以及每个表的字段都要详细说明,包括,字段名称、类型、作用2,使用markdown的输出格式,字段的描述需要使用表格展示3,如果表之间有关系,需要描述清楚表之间的关系

回答

课程管理表(tb_course)说明文档

表简介

tb_course表用于存储课程相关的管理信息,包括课程的基本属性、价格、适用人群等详情,以及操作日志信息如创建人、修改人及操作时间。该表采用InnoDB存储引擎,字符集为utf8mb4,以支持广泛的多语言字符。

字段详细说明
字段名称数据类型是否可空默认值作用
idINTNO主键ID,自增字段,唯一标识每条课程记录
course_codeVARCHAR(255)NO课程编码,用于内部识别课程,确保唯一性
course_subjectVARCHAR(100)NO课程学科,如Java、Python、大数据等,描述课程所属的学科领域
course_nameVARCHAR(255)NO课程名称,课程的完整标题,便于用户直观了解课程内容
course_priceINTYES课程价格,以整数形式表示,单位通常为货币的基本单位,如元
target_audienceVARCHAR(100)YES适用人群,描述课程目标受众,如“初学者”、“中级开发者”等,帮助用户判断是否适合自己
course_introductionTEXTYES课程介绍,对课程内容、目标、亮点等进行简要描述,帮助潜在学员了解课程详情
create_timeDATETIMEYES创建时间,记录课程信息首次录入数据库的时间点
update_timeDATETIMEYES修改时间,记录每次课程信息更新时的时间点
create_byVARCHAR(64)YES创建人,记录最初创建此课程记录的用户ID或用户名
update_byVARCHAR(64)YES修改人,记录最近一次修改此课程记录的用户ID或用户名
remarkVARCHAR(255)YES备注,用于记录额外的、非结构化的关于课程的信息或说明
表间关系

当前tb_course表在提供的SQL脚本中没有直接显式的与其他表建立关系。这意味着它作为一个独立的实体存在,用于存储课程的基础信息。如果未来存在扩展需求,例如关联教师表(讲师信息)、学生选课表等,可以通过外键关联来实现。例如,一个tb_teacher_course表可以用来表示教师与课程的多对多关系,其中包含teacher_idcourse_id作为外键分别引用教师表和tb_course表的主键。

目前,文档仅描述了tb_course表本身的信息,若有关联表或进一步的关系定义需求,请提供相应的SQL脚本或详细说明。


生成代码

代码生成算是比较常规的方案,用的也比较多,分为了几种情况

  • 给出表生成代码(项目中常见)
    • 给出表结构的ddl,可以输出这个表的增删改查的所有代码
    • 给出表结构的dll,可以输出增删改查的接口文档
  • 补全代码
    • 例1-给出实体类,帮助编写getter、setter、toString、构造方法等等
    • 例2-给出一个controller,帮助编写swagger注解等
  • 提取结构(无含金量,费时间的编程)
    • 例1-根据接口文档提取dto类或者vo类

生成代码流程图

有一些比较复杂的业务流程,往往需要画出流程图,现在就可以使用ai协助我们画流程图

你是一个软件工程师,为了方便理解代码执行流程,需要给出代码执行的流程图,代码如下:// 创建工单@Transactional@Overridepublic int insertTaskDto(TaskDto taskDto) {//1. 查询售货机是否存在VendingMachine vm = vendingMachineService.selectVendingMachineByInnerCode(taskDto.getInnerCode());if (vm == null) {throw new ServiceException("设备不存在");}//2. 校验售货机状态与工单类型是否相符checkCreateTask(vm.getVmStatus(), taskDto.getProductTypeId());//3. 校验这台设备是否有未完成的同类型工单,如果存在则不能创建hasTask(taskDto.getInnerCode(), taskDto.getProductTypeId());//4. 校验员工是否存在Emp emp = empService.selectEmpById(taskDto.getUserId());if (emp == null) {throw new ServiceException("员工不存在");}// 5. 校验非同区域下的工作人员不能接受工单if (emp.getRegionId() != vm.getRegionId()) {throw new ServiceException("非同区域下的工作人员不能接受工单");}//6. 保存工单信息Task task = new Task();BeanUtil.copyProperties(taskDto, task);// 属性赋值task.setCreateTime(DateUtils.getNowDate());// 创建时间task.setTaskCode(generateTaskCode());// 工单编号 202405150001task.setTaskStatus(DkdContants.TASK_STATUS_CREATE);// 创建工单task.setAddr(vm.getAddr());task.setRegionId(vm.getRegionId());task.setUserName(emp.getUserName());int taskResult = taskMapper.insertTask(task);//7. 如果是补货工单,向工单明细表插入记录if (task.getProductTypeId() == DkdContants.TASK_TYPE_SUPPLY) {if (CollUtil.isEmpty(taskDto.getDetails())) {throw new ServiceException("补货工单明细不能为空");}List<TaskDetails> taskDetailsList = taskDto.getDetails().stream().map(details -> {TaskDetails taskDetails = BeanUtil.copyProperties(details, TaskDetails.class);taskDetails.setTaskId(task.getTaskId());return taskDetails;}).collect(Collectors.toList());taskDetailsService.insertBatch(taskDetailsList);}return taskResult;
}输出:请使用mermaid语言来描述这个方法的流程

回答

非补货
补货
查询售货机
售货机存在?
抛出异常: 设备不存在
校验售货机状态与工单类型
校验通过
检查同类型未完成工单
无同类型工单?
抛出异常: 工单冲突
查询员工
员工存在?
抛出异常: 员工不存在
校验员工区域
区域相同?
抛出异常: 区域不符
构建并保存工单
保存成功?
异常处理
判断工单类型
结束
处理补货工单明细
明细处理完成?
异常处理

在这个Mermaid流程图中,我描述了从开始到结束整个insertTaskDto方法的执行流程,包括每个步骤的判断逻辑和可能的异常处理路径。箭头指向代表流程的走向,方框内的文字描述了具体的操作或判断条件,而带问号的方框则表示一个决策节点。

这篇关于通义千问AI+Java的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1076546

相关文章

揭秘未来艺术:AI绘画工具全面介绍

📑前言 随着科技的飞速发展,人工智能(AI)已经逐渐渗透到我们生活的方方面面。在艺术创作领域,AI技术同样展现出了其独特的魅力。今天,我们就来一起探索这个神秘而引人入胜的领域,深入了解AI绘画工具的奥秘及其为艺术创作带来的革命性变革。 一、AI绘画工具的崛起 1.1 颠覆传统绘画模式 在过去,绘画是艺术家们通过手中的画笔,蘸取颜料,在画布上自由挥洒的创造性过程。然而,随着AI绘画工

Java五子棋之坐标校正

上篇针对了Java项目中的解构思维,在这篇内容中我们不妨从整体项目中拆解拿出一个非常重要的五子棋逻辑实现:坐标校正,我们如何使漫无目的鼠标点击变得有序化和可控化呢? 目录 一、从鼠标监听到获取坐标 1.MouseListener和MouseAdapter 2.mousePressed方法 二、坐标校正的具体实现方法 1.关于fillOval方法 2.坐标获取 3.坐标转换 4.坐

Spring Cloud:构建分布式系统的利器

引言 在当今的云计算和微服务架构时代,构建高效、可靠的分布式系统成为软件开发的重要任务。Spring Cloud 提供了一套完整的解决方案,帮助开发者快速构建分布式系统中的一些常见模式(例如配置管理、服务发现、断路器等)。本文将探讨 Spring Cloud 的定义、核心组件、应用场景以及未来的发展趋势。 什么是 Spring Cloud Spring Cloud 是一个基于 Spring

Javascript高级程序设计(第四版)--学习记录之变量、内存

原始值与引用值 原始值:简单的数据即基础数据类型,按值访问。 引用值:由多个值构成的对象即复杂数据类型,按引用访问。 动态属性 对于引用值而言,可以随时添加、修改和删除其属性和方法。 let person = new Object();person.name = 'Jason';person.age = 42;console.log(person.name,person.age);//'J

java8的新特性之一(Java Lambda表达式)

1:Java8的新特性 Lambda 表达式: 允许以更简洁的方式表示匿名函数(或称为闭包)。可以将Lambda表达式作为参数传递给方法或赋值给函数式接口类型的变量。 Stream API: 提供了一种处理集合数据的流式处理方式,支持函数式编程风格。 允许以声明性方式处理数据集合(如List、Set等)。提供了一系列操作,如map、filter、reduce等,以支持复杂的查询和转

一份LLM资源清单围观技术大佬的日常;手把手教你在美国搭建「百万卡」AI数据中心;为啥大模型做不好简单的数学计算? | ShowMeAI日报

👀日报&周刊合集 | 🎡ShowMeAI官网 | 🧡 点赞关注评论拜托啦! 1. 为啥大模型做不好简单的数学计算?从大模型高考数学成绩不及格说起 司南评测体系 OpenCompass 选取 7 个大模型 (6 个开源模型+ GPT-4o),组织参与了 2024 年高考「新课标I卷」的语文、数学、英语考试,然后由经验丰富的判卷老师评判得分。 结果如上图所

Java面试八股之怎么通过Java程序判断JVM是32位还是64位

怎么通过Java程序判断JVM是32位还是64位 可以通过Java程序内部检查系统属性来判断当前运行的JVM是32位还是64位。以下是一个简单的方法: public class JvmBitCheck {public static void main(String[] args) {String arch = System.getProperty("os.arch");String dataM

AI儿童绘本创作

之前分享过AI儿童绘画的项目,但是主要问题是角色一致要花费很长的时间! 今天发现了这款,非常奈斯! 只需输入故事主题、风格、模板,软件就会自动创作故事内容,自动生成插画配图,自动根据模板生成成品,测试效果如下图。 变现方式:生成儿童绘本发布到各平台,吸引宝妈群体进私域。  百度网盘 请输入提取码百度网盘为您提供文件的网络备份、同步和分享服务。空间大、速度快、安全

详细分析Springmvc中的@ModelAttribute基本知识(附Demo)

目录 前言1. 注解用法1.1 方法参数1.2 方法1.3 类 2. 注解场景2.1 表单参数2.2 AJAX请求2.3 文件上传 3. 实战4. 总结 前言 将请求参数绑定到模型对象上,或者在请求处理之前添加模型属性 可以在方法参数、方法或者类上使用 一般适用这几种场景: 表单处理:通过 @ModelAttribute 将表单数据绑定到模型对象上预处理逻辑:在请求处理之前

eclipse运行springboot项目,找不到主类

解决办法尝试了很多种,下载sts压缩包行不通。最后解决办法如图: help--->Eclipse Marketplace--->Popular--->找到Spring Tools 3---->Installed。