如何提问
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,请为每个字段都添加上comment
5,帮我给生成的表中插入一些IT课程示例数据
课程学科:Java、人工智能、大数据
适用人群:小白学员、中级程序员
回答:
基于您的需求,以下是创建
tb_course
表的SQL语句,包含了指定的字段、约束条件以及注释,并且我会为您插入一些示例数据:
CREATETABLE`tb_course`(`id`INTAUTO_INCREMENTPRIMARYKEYCOMMENT'主键ID',`course_code`VARCHAR(50)NOTNULLCOMMENT'课程编码',`subject`VARCHAR(100)NOTNULLCOMMENT'课程学科',`course_name`VARCHAR(255)NOTNULLCOMMENT'课程名称',`course_price`INTNOTNULLCOMMENT'课程价格(单位:元)',`target_audience`VARCHAR(100)NOTNULLCOMMENT'适用人群',`course_introduction`TEXTCOMMENT'课程介绍',`create_time`DATETIMEDEFAULTCURRENT_TIMESTAMPCOMMENT'创建时间',`update_time`DATETIMEONUPDATECURRENT_TIMESTAMPCOMMENT'修改时间',`create_by`VARCHAR(50)COMMENT'创建人',`update_by`VARCHAR(50)COMMENT'修改人',`remark`VARCHAR(255)COMMENT'备注')ENGINE=InnoDBDEFAULTCHARSET=utf8mb4 COMMENT='课程管理表';-- 插入示例数据INSERTINTO`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_id
和
course_id
作为外键分别引用教师表和
tb_course
表的主键。
目前,文档仅描述了
tb_course
表本身的信息,若有关联表或进一步的关系定义需求,请提供相应的SQL脚本或详细说明。
生成代码
代码生成算是比较常规的方案,用的也比较多,分为了几种情况
- 给出表生成代码(项目中常见) - 给出表结构的ddl,可以输出这个表的增删改查的所有代码- 给出表结构的dll,可以输出增删改查的接口文档
- 补全代码 - 例1-给出实体类,帮助编写getter、setter、toString、构造方法等等- 例2-给出一个controller,帮助编写swagger注解等
- 提取结构(无含金量,费时间的编程) - 例1-根据接口文档提取dto类或者vo类
生成代码流程图
有一些比较复杂的业务流程,往往需要画出流程图,现在就可以使用ai协助我们画流程图
你是一个软件工程师,为了方便理解代码执行流程,需要给出代码执行的流程图,代码如下:
// 创建工单@Transactional@OverridepublicintinsertTaskDto(TaskDto taskDto){//1. 查询售货机是否存在VendingMachine vm = vendingMachineService.selectVendingMachineByInnerCode(taskDto.getInnerCode());if(vm ==null){thrownewServiceException("设备不存在");}//2. 校验售货机状态与工单类型是否相符checkCreateTask(vm.getVmStatus(), taskDto.getProductTypeId());//3. 校验这台设备是否有未完成的同类型工单,如果存在则不能创建hasTask(taskDto.getInnerCode(), taskDto.getProductTypeId());//4. 校验员工是否存在Emp emp = empService.selectEmpById(taskDto.getUserId());if(emp ==null){thrownewServiceException("员工不存在");}// 5. 校验非同区域下的工作人员不能接受工单if(emp.getRegionId()!= vm.getRegionId()){thrownewServiceException("非同区域下的工作人员不能接受工单");}//6. 保存工单信息Task task =newTask();BeanUtil.copyProperties(taskDto, task);// 属性赋值
task.setCreateTime(DateUtils.getNowDate());// 创建时间
task.setTaskCode(generateTaskCode());// 工单编号 202405150001
task.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())){thrownewServiceException("补货工单明细不能为空");}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-svg-UbQO0ykn3WSmnvNh {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-UbQO0ykn3WSmnvNh .error-icon{fill:#552222;}#mermaid-svg-UbQO0ykn3WSmnvNh .error-text{fill:#552222;stroke:#552222;}#mermaid-svg-UbQO0ykn3WSmnvNh .edge-thickness-normal{stroke-width:2px;}#mermaid-svg-UbQO0ykn3WSmnvNh .edge-thickness-thick{stroke-width:3.5px;}#mermaid-svg-UbQO0ykn3WSmnvNh .edge-pattern-solid{stroke-dasharray:0;}#mermaid-svg-UbQO0ykn3WSmnvNh .edge-pattern-dashed{stroke-dasharray:3;}#mermaid-svg-UbQO0ykn3WSmnvNh .edge-pattern-dotted{stroke-dasharray:2;}#mermaid-svg-UbQO0ykn3WSmnvNh .marker{fill:#333333;stroke:#333333;}#mermaid-svg-UbQO0ykn3WSmnvNh .marker.cross{stroke:#333333;}#mermaid-svg-UbQO0ykn3WSmnvNh svg{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;}#mermaid-svg-UbQO0ykn3WSmnvNh .label{font-family:"trebuchet ms",verdana,arial,sans-serif;color:#333;}#mermaid-svg-UbQO0ykn3WSmnvNh .cluster-label text{fill:#333;}#mermaid-svg-UbQO0ykn3WSmnvNh .cluster-label span{color:#333;}#mermaid-svg-UbQO0ykn3WSmnvNh .label text,#mermaid-svg-UbQO0ykn3WSmnvNh span{fill:#333;color:#333;}#mermaid-svg-UbQO0ykn3WSmnvNh .node rect,#mermaid-svg-UbQO0ykn3WSmnvNh .node circle,#mermaid-svg-UbQO0ykn3WSmnvNh .node ellipse,#mermaid-svg-UbQO0ykn3WSmnvNh .node polygon,#mermaid-svg-UbQO0ykn3WSmnvNh .node path{fill:#ECECFF;stroke:#9370DB;stroke-width:1px;}#mermaid-svg-UbQO0ykn3WSmnvNh .node .label{text-align:center;}#mermaid-svg-UbQO0ykn3WSmnvNh .node.clickable{cursor:pointer;}#mermaid-svg-UbQO0ykn3WSmnvNh .arrowheadPath{fill:#333333;}#mermaid-svg-UbQO0ykn3WSmnvNh .edgePath .path{stroke:#333333;stroke-width:2.0px;}#mermaid-svg-UbQO0ykn3WSmnvNh .flowchart-link{stroke:#333333;fill:none;}#mermaid-svg-UbQO0ykn3WSmnvNh .edgeLabel{background-color:#e8e8e8;text-align:center;}#mermaid-svg-UbQO0ykn3WSmnvNh .edgeLabel rect{opacity:0.5;background-color:#e8e8e8;fill:#e8e8e8;}#mermaid-svg-UbQO0ykn3WSmnvNh .cluster rect{fill:#ffffde;stroke:#aaaa33;stroke-width:1px;}#mermaid-svg-UbQO0ykn3WSmnvNh .cluster text{fill:#333;}#mermaid-svg-UbQO0ykn3WSmnvNh .cluster span{color:#333;}#mermaid-svg-UbQO0ykn3WSmnvNh div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:12px;background:hsl(80, 100%, 96.2745098039%);border:1px solid #aaaa33;border-radius:2px;pointer-events:none;z-index:100;}#mermaid-svg-UbQO0ykn3WSmnvNh :root{--mermaid-font-family:"trebuchet ms",verdana,arial,sans-serif;}
否
是
否
是
否
是
否
是
否
是
非补货
补货
否
是
查询售货机
售货机存在?
抛出异常: 设备不存在
校验售货机状态与工单类型
校验通过
检查同类型未完成工单
无同类型工单?
抛出异常: 工单冲突
查询员工
员工存在?
抛出异常: 员工不存在
校验员工区域
区域相同?
抛出异常: 区域不符
构建并保存工单
保存成功?
异常处理
判断工单类型
结束
处理补货工单明细
明细处理完成?
异常处理
在这个Mermaid流程图中,我描述了从开始到结束整个
insertTaskDto
方法的执行流程,包括每个步骤的判断逻辑和可能的异常处理路径。箭头指向代表流程的走向,方框内的文字描述了具体的操作或判断条件,而带问号的方框则表示一个决策节点。
版权归原作者 无条件做异梦 所有, 如有侵权,请联系我们删除。