位置: IT常识 - 正文

谷粒学院开发(二):教师管理模块(谷粒学院项目含金量)

编辑:rootadmin
谷粒学院开发(二):教师管理模块 前后端分离开发前端 html, css, js, jq 主要作用:数据显示 ajax后端 controller service mapper 主要作用:返回数据或操作数据 接口讲师管理模块(后端)准备工作

推荐整理分享谷粒学院开发(二):教师管理模块(谷粒学院项目含金量),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:谷粒学院简历,谷粒学院 设计模式,谷粒学院架构图,谷粒学苑,谷粒学院简历,谷粒学院架构图,谷粒学院架构图,谷粒学院官网,内容如对您有帮助,希望把文章链接给更多的朋友!

创建数据库,创建讲师数据库表

CREATE TABLE `edu_teacher` ( `id` char(19) NOT NULL COMMENT '讲师ID', `name` varchar(20) NOT NULL COMMENT '讲师姓名', `intro` varchar(500) NOT NULL DEFAULT '' COMMENT '讲师简介', `career` varchar(500) DEFAULT NULL COMMENT '讲师资历,一句话说明讲师', `level` int(10) unsigned NOT NULL COMMENT '头衔 1高级讲师 2首席讲师', `avatar` varchar(255) DEFAULT NULL COMMENT '讲师头像', `sort` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '排序', `is_deleted` tinyint(1) unsigned NOT NULL DEFAULT '0' COMMENT '逻辑删除 1(true)已删除, 0(false)未删除', `gmt_create` datetime NOT NULL COMMENT '创建时间', `gmt_modified` datetime NOT NULL COMMENT '更新时间', PRIMARY KEY (`id`), UNIQUE KEY `uk_name` (`name`)) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='讲师';创建父工程 pom类型,管理版本依赖和公共依赖 springboot工程子模块1 maven工程子子模块1 maven工程子子模块2子模块2创建项目结构

创建父工程,在pom.xml里面加上一个标签,将它修改成pom工程

把dependiences删掉,放在子模块中,父工程只管理版本 添加下面的标签确定依赖版本

<properties> <java.version>1.8</java.version> <guli.version>0.0.1-SNAPSHOT</guli.version> <mybatis-plus.version>3.0.5</mybatis-plus.version> <velocity.version>2.0</velocity.version> <swagger.version>2.7.0</swagger.version> <aliyun.oss.version>2.8.3</aliyun.oss.version> <jodatime.version>2.10.1</jodatime.version> <poi.version>3.17</poi.version> <commons-fileupload.version>1.3.3</commons-fileupload.version> <commons-io.version>2.6</commons-io.version> <httpclient.version>4.5.1</httpclient.version> <jwt.version>0.7.0</jwt.version> <aliyun-java-sdk-core.version>4.3.3</aliyun-java-sdk-core.version> <aliyun-sdk-oss.version>3.1.0</aliyun-sdk-oss.version> <aliyun-java-sdk-vod.version>2.15.2</aliyun-java-sdk-vod.version> <aliyun-java-vod-upload.version>1.4.11</aliyun-java-vod-upload.version> <aliyun-sdk-vod-upload.version>1.4.11</aliyun-sdk-vod-upload.version> <fastjson.version>1.2.28</fastjson.version> <gson.version>2.8.2</gson.version> <json.version>20170516</json.version> <commons-dbutils.version>1.7</commons-dbutils.version> <canal.client.version>1.1.0</canal.client.version> <docker.image.prefix>zx</docker.image.prefix> <cloud-alibaba.version>0.2.2.RELEASE</cloud-alibaba.version> <swagger-version>2.0.1</swagger-version> <project-version>0.0.1-SNAPSHOT</project-version></properties>

配置<dependencyManagement>锁定依赖的版本

<dependencyManagement> <dependencies> <!--Spring Cloud--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Hoxton.RELEASE</version> <type>pom</type> <scope>import</scope> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-alibaba-dependencies</artifactId> <version>${cloud-alibaba.version}</version> <type>pom</type> <scope>import</scope> </dependency> <!--mybatis-plus 持久层--> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>${mybatis-plus.version}</version> </dependency> <!-- velocity 模板引擎, Mybatis Plus 代码生成器需要 --> <dependency> <groupId>org.apache.velocity</groupId> <artifactId>velocity-engine-core</artifactId> <version>${velocity.version}</version> </dependency> <!--swagger--> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>${swagger.version}</version> </dependency> <!--swagger ui--> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>${swagger.version}</version> </dependency> <!--aliyunOSS--> <dependency> <groupId>com.aliyun.oss</groupId> <artifactId>aliyun-sdk-oss</artifactId> <version>${aliyun.oss.version}</version> </dependency> <!--日期时间工具--> <dependency> <groupId>joda-time</groupId> <artifactId>joda-time</artifactId> <version>${jodatime.version}</version> </dependency> <!--xls--> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>${poi.version}</version> </dependency> <!--xlsx--> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>${poi.version}</version> </dependency> <!--文件上传--> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>${commons-fileupload.version}</version> </dependency> <!--commons-io--> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>${commons-io.version}</version> </dependency> <!--httpclient--> <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpclient</artifactId> <version>${httpclient.version}</version> </dependency> <dependency> <groupId>com.google.code.gson</groupId> <artifactId>gson</artifactId> <version>${gson.version}</version> </dependency> <!-- JWT --> <dependency> <groupId>io.jsonwebtoken</groupId> <artifactId>jjwt</artifactId> <version>${jwt.version}</version> </dependency> <!--aliyun--> <dependency> <groupId>com.aliyun</groupId> <artifactId>aliyun-java-sdk-core</artifactId> <version>${aliyun-java-sdk-core.version}</version> </dependency> <dependency> <groupId>com.aliyun.oss</groupId> <artifactId>aliyun-sdk-oss</artifactId> <version>${aliyun-sdk-oss.version}</version> </dependency> <dependency> <groupId>com.aliyun</groupId> <artifactId>aliyun-java-sdk-vod</artifactId> <version>${aliyun-java-sdk-vod.version}</version> </dependency> <dependency> <groupId>com.aliyun</groupId> <artifactId>aliyun-java-vod-upload</artifactId> <version>${aliyun-java-vod-upload.version}</version> </dependency> <dependency> <groupId>com.aliyun</groupId> <artifactId>aliyun-sdk-vod-upload</artifactId> <version>${aliyun-sdk-vod-upload.version}</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>${fastjson.version}</version> </dependency> <dependency> <groupId>org.json</groupId> <artifactId>json</artifactId> <version>${json.version}</version> </dependency> <dependency> <groupId>commons-dbutils</groupId> <artifactId>commons-dbutils</artifactId> <version>${commons-dbutils.version}</version> </dependency> <dependency> <groupId>com.alibaba.otter</groupId> <artifactId>canal.client</artifactId> <version>${canal.client.version}</version> </dependency> <dependency> <groupId>com.github.xiaoymin</groupId> <artifactId>knife4j-spring-boot-starter</artifactId> <version>${swagger-version}</version> </dependency> <dependency> <groupId>com.jack</groupId> <artifactId>service</artifactId> <version>${project-version}</version> </dependency> <dependency> <groupId>com.liuscoding</groupId> <artifactId>common_utils</artifactId> <version>${project-version}</version> </dependency> </dependencies></dependencyManagement>创建子模块

同样创建之后添加packing标签,导入依赖

<dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-ribbon</artifactId> </dependency> <!--hystrix依赖,主要是用 @HystrixCommand --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-hystrix</artifactId> </dependency> <!--服务注册--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <!--服务调用--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!--mybatis-plus--> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> </dependency> <!--mysql--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <!-- velocity 模板引擎, Mybatis Plus 代码生成器需要 --> <dependency> <groupId>org.apache.velocity</groupId> <artifactId>velocity-engine-core</artifactId> </dependency> <!--swagger--> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> </dependency> <!--lombok用来简化实体类:需要安装lombok插件--> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> </dependency> <!--xls--> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> </dependency> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> </dependency> <!--httpclient--> <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpclient</artifactId> </dependency> <!--commons-io--> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> </dependency> <!--gson--> <dependency> <groupId>com.google.code.gson</groupId> <artifactId>gson</artifactId> </dependency> <dependency> <groupId>com.jack</groupId> <artifactId>service</artifactId> </dependency> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> </dependency></dependencies>创建子子模块

讲师管理模块配置

创建application.properties

# 服务端口server.port=8001# 服务名spring.application.name=service_edu# 环境配置: dev, test, prodspring.profiles.active=dev# mysql数据库连接spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driverspring.datasource.url=jdbc:mysql://localhost:3306/guli?serverTimezone=GMT%2B8spring.datasource.username=rootspring.datasource.password=xxxxx# mybatis日志mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl编写controller service mapper代码内容

mp提供了代码生成器,生成相关代码

public class CodeGenerator { @Test public void run() { // 1、创建代码生成器 AutoGenerator mpg = new AutoGenerator(); // 2、全局配置 GlobalConfig gc = new GlobalConfig(); String projectPath = System.getProperty("user.dir"); gc.setOutputDir(projectPath + "/src/main/java"); gc.setAuthor("testjava"); gc.setOpen(false); //生成后是否打开资源管理器 gc.setFileOverride(false); //重新生成时文件是否覆盖 gc.setServiceName("%sService");//去掉Service接口的首字母I gc.setIdType(IdType.ID_WORKER); //主键策略 gc.setDateType(DateType.ONLY_DATE);//定义生成的实体类中日期类型 gc.setSwagger2(true);//开启Swagger2模式 mpg.setGlobalConfig(gc); // 3、数据源配置 DataSourceConfig dsc = new DataSourceConfig(); dsc.setUrl("jdbc:mysql://localhost:3306/guli?serverTimezone=GMT%2B8"); dsc.setDriverName("com.mysql.cj.jdbc.Driver"); dsc.setUsername("root"); dsc.setPassword("020406"); dsc.setDbType(DbType.MYSQL); mpg.setDataSource(dsc); // 4、包配置 PackageConfig pc = new PackageConfig(); pc.setParent("com.jack"); pc.setModuleName("eduservice"); //模块名 pc.setController("controller"); pc.setEntity("entity"); pc.setService("service"); pc.setMapper("mapper"); mpg.setPackageInfo(pc); // 5、策略配置 StrategyConfig strategy = new StrategyConfig(); strategy.setInclude("edu_teacher"); // 表名称 strategy.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略 strategy.setTablePrefix(pc.getModuleName() + "_"); //生成实体时去掉表前缀 strategy.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射到实体的命名策略 strategy.setEntityLombokModel(true); // lombok 模型 @Accessors(chain = true) setter链式操作 strategy.setRestControllerStyle(true); //restful api风格控制器 strategy.setControllerMappingHyphenStyle(true); //url中驼峰转连字符 mpg.setStrategy(strategy); // 6、执行 mpg.execute(); }}

生成出来的结果

测试一下编写Controller@RestController@RequestMapping("/eduservice/teacher")public class EduTeacherController { @Autowired EduTeacherService eduTeacherService; // 1. 查询讲师表所有数据 @GetMapping("findAll") public List<EduTeacher> findAllTeacher() { // 调用service的方法实现查询所有的操作 List<EduTeacher> list = eduTeacherService.list(null); return list; }}

创建启动类

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

新建配置类,添加mapperscan注解

@Configuration@MapperScan("com.jack.eduservice.mapper")public class EduConfig {}

给Mapper加上@Mapper注解

设置日期格式

# 设置日期格式spring.jackson.date-format=yyyy-MM-dd HH:mm:ssspring.jackson.time-zone=GMT+8

测试

讲师逻辑删除功能

在配置类里配置逻辑删除插件

@Beanpublic ISqlInjector sqlInjector() { return new LogicSqlInjector();}

在实体类属性上加上注解

@ApiModelProperty(value = "逻辑删除 1(true)已删除, 0(false)未删除")@TableLogicprivate Integer isDeleted;

编写Controller方法

@DeleteMapping("{id}")public boolean removeTeacher(@PathVariable Integer id) { return eduTeacherService.removeById(id);}谷粒学院开发(二):教师管理模块(谷粒学院项目含金量)

如何测试 delete提交没有办法通过浏览器直接提交 借助一些工具进行测试: 1. swagger测试(重点) 2. postman(了解)

整合swagger

生成在线接口文档方便接口测试创建一个公共模块

整合swagger,为了所有模块都能用

创建子模块common,再创建service_base模块,新建配置类

@Configuration@EnableSwagger2public class SwaggerConfig { @Bean public Docket webApiConfig(){ return new Docket(DocumentationType.SWAGGER_2) .groupName("webApi") .apiInfo(webApiInfo()) .select() .paths(Predicates.not(PathSelectors.regex("/admin/.*"))) .paths(Predicates.not(PathSelectors.regex("/error.*"))) .build(); } private ApiInfo webApiInfo(){ return new ApiInfoBuilder() .title("网站-课程中心API文档") .description("本文档描述了课程中心微服务接口定义") .version("1.0") .contact(new Contact("java", "http://atguigu.com", "1123@qq.com")) .build(); }}具体使用

在service_edu中引入service_base依赖 还需要在启动类配置扫描组件,以便Swagger的配置类生效

@SpringBootApplication@ComponentScan(basePackages = {"com.jack"})public class EduApplication { public static void main(String[] args) { SpringApplication.run(EduApplication.class, args); }}访问swagger

http://localhost:8001/swagger-ui.html

可以在Controller上添加注解,增强swagger文档的可读性

统一返回数据格式

在common模块创建子模块 common_utils

创建interface,定义数据返回状态码

成功 20000失败 20001public interface ResultCode { public static Integer SUCCESS = 20000; public static Integer ERROR = 20001;}

创建结果类

package com.jack.commonutils;import io.swagger.annotations.ApiModelProperty;import lombok.Data;import java.util.HashMap;import java.util.Map;// 统一返回结果的类@Datapublic class R { @ApiModelProperty(value = "是否成功") private Boolean success; @ApiModelProperty(value = "返回码") private Integer code; @ApiModelProperty(value = "返回消息") private String message; @ApiModelProperty(value = "返回数据") private Map<String, Object> data = new HashMap<>(); // 把构造方法私有化 private R() {} // 静态方法 public static R ok() { R r = new R(); r.setSuccess(true); r.setCode(ResultCode.SUCCESS); r.setMessage("成功"); return r; } // 失败 public static R error() { R r = new R(); r.setSuccess(false); r.setCode(ResultCode.ERROR); r.setMessage("失败"); return r; } public R success(Boolean success) { this.setSuccess(success); return this; } public R message(String message) { this.setMessage(message); return this; } public R code(Integer code) { this.setCode(code); return this; } public R data(String key, Object value) { this.data.put(key, value); return this; } public R data(Map<String, Object> map) { this.setData(map); return this; }}

使用统一结果

先在Service模块引入依赖<dependency> <groupId>com.jack</groupId> <artifactId>common_utils</artifactId></dependency>

将Controller中的返回值都改为R类型

@Api(description = "讲师管理")@RestController@RequestMapping("/eduservice/teacher")public class EduTeacherController { @Autowired EduTeacherService eduTeacherService; // 1. 查询讲师表所有数据 @ApiOperation(value = "所有讲师列表") @GetMapping("findAll") public R findAllTeacher() { // 调用service的方法实现查询所有的操作 List<EduTeacher> list = eduTeacherService.list(null); return R.ok().data("list", list); } @ApiOperation(value = "根据ID删除讲师") @DeleteMapping("{id}") public R removeTeacher(@PathVariable String id) { boolean flag = eduTeacherService.removeById(id); if(flag) { return R.ok(); } else { return R.error(); } }}讲师分页功能

配置分页插件

@Beanpublic PaginationInterceptor paginationInterceptor() { return new PaginationInterceptor();}

编写讲师分页查询方法

// 分页查询讲师方法@GetMapping("pageTeacher/{current}/{limit}")public R pageListTeacher(@PathVariable("current")Long current, @PathVariable("limit") Long limit) { // 创建page对象 Page<EduTeacher> page = new Page<>(current, limit); // 调用方法实现分页 // 调用方法的时候,底层封装,把分页的数据封装到page对象里面 eduTeacherService.page(page, null); long total = page.getTotal(); // 总记录数 List<EduTeacher> records = page.getRecords();/* Map map = new HashMap(); map.put("total", total); map.put("rows", records); return R.ok().data(map);*/ return R.ok().data("total", total).data("rows", records);}多条件组合分页查询

把条件值传递到接口里面 把条件值封装到对象里面,把对象传递到接口里面 (VO对象) 创建VO类

@Data@ApiModel("教师查询对象")public class TeacherQuery { @ApiModelProperty("教师名称,模糊查询") private String name; @ApiModelProperty("头衔 1 高级讲师 2 首席讲师") private Integer level; @ApiModelProperty(value = "查询开始时间",example = "2020-01-01 10:10:10") /** * 注意,这里使用的是String类型,前端传过来的数据无需进行类型转换。 */ private String begin; @ApiModelProperty(value = "查询结束时间",example = "2020-04-01 10:10:10") private String end;}

根据条件值进行判断,拼接条件

@ApiOperation("多条件组合查询带分页")@GetMapping("pageTeacherCondition/{current}/{limit}")public R pageTeacherCondition(@PathVariable long current, @PathVariable long limit, TeacherQuery teacherQuery) { Page<EduTeacher> page = new Page<>(current, limit); // 构建条件 QueryWrapper<EduTeacher> queryWrapper = new QueryWrapper<>(); String name = teacherQuery.getName(); Integer level = teacherQuery.getLevel(); String begin = teacherQuery.getBegin(); String end = teacherQuery.getEnd(); // 判断条件是否为空,加上不为空的条件 if(!StringUtils.isEmpty(name)) { queryWrapper.like("name", name); } if(!StringUtils.isEmpty(level)) { queryWrapper.eq("level", level); } if(!StringUtils.isEmpty(begin)) { queryWrapper.ge("gmt_create", begin); } if(!StringUtils.isEmpty(end)) { queryWrapper.le("gmt_create", end); } eduTeacherService.page(page, queryWrapper); long total = page.getTotal(); // 总记录数 List<EduTeacher> records = page.getRecords(); // list return R.ok().data("total", total).data("rows", records);}讲师添加

配置字段自动填充

编写Controller

@ApiOperation("添加讲师")@PostMapping("addTeacher")public R addTeacher(@RequestBody EduTeacher eduTeacher) { boolean save = eduTeacherService.save(eduTeacher); if(save) { return R.ok(); } else { return R.error(); }}讲师修改功能

根据讲师id进行查询,用于回显

@ApiOperation("根据讲师id进行查询")@GetMapping("getTeacher/{id}")public R getTeacher(@PathVariable String id) { EduTeacher teacher = eduTeacherService.getById(id); return R.ok().data("teacher", teacher);}

讲师修改

@ApiOperation("讲师修改")@PostMapping("updateTeacher")public R updateTeacher(@RequestBody EduTeacher teacher) { boolean b = eduTeacherService.updateById(teacher); return b ? R.ok() : R.error();}统一异常处理

统一异常处理类

@ControllerAdvicepublic class GlobalExceptionHandler { @ExceptionHandler(Exception.class) // 指定出现什么异常会被处理 @ResponseBody // 为了能够返回数据 public R error(Exception e) { e.printStackTrace(); return R.error().message("执行了全局异常处理"); }}
本文链接地址:https://www.jiuchutong.com/zhishi/300408.html 转载请保留说明!

上一篇:【JWT鉴权】如何来写一个token令牌认证登录?(jwt 鉴权)

下一篇:【蓝桥杯】第十四届蓝桥杯模拟赛(第三期)C++ (弱go的记录,有问题的话求指点)(第十届蓝桥杯大赛个人赛省赛结果)

  • 社群运营不得不知的6个隐秘技巧(社群运营通俗理解)

    社群运营不得不知的6个隐秘技巧(社群运营通俗理解)

  • 苹果4s怎么下载低版本软件(苹果4s怎么下载歌曲)(苹果手机怎样下载软件)

    苹果4s怎么下载低版本软件(苹果4s怎么下载歌曲)(苹果手机怎样下载软件)

  • 京东寄件怎么操作(京东怎样寄东西)

    京东寄件怎么操作(京东怎样寄东西)

  • 荣耀magic3怎么关闭应用(荣耀Magic3怎么关闭双击屏幕放大)

    荣耀magic3怎么关闭应用(荣耀Magic3怎么关闭双击屏幕放大)

  • 默认网关怎么设置(默认网关怎么设置正确csico)

    默认网关怎么设置(默认网关怎么设置正确csico)

  • 华为手机截屏设置在哪里(华为手机截屏怎么操作)

    华为手机截屏设置在哪里(华为手机截屏怎么操作)

  • 嗨回收旧空调收不收拆机费(回收旧空调一般多少钱一个)

    嗨回收旧空调收不收拆机费(回收旧空调一般多少钱一个)

  • 华为荣耀9x怎么关机重启(华为荣耀9x怎么分屏)

    华为荣耀9x怎么关机重启(华为荣耀9x怎么分屏)

  • 工业互联网的三大要素是什么(工业互联网的三大核心要素)

    工业互联网的三大要素是什么(工业互联网的三大核心要素)

  • 管理员怎么改成员专属头衔(管理员怎么改成员头衔)

    管理员怎么改成员专属头衔(管理员怎么改成员头衔)

  • p系列和mate系列的区别(p系列和mate系列拍照)

    p系列和mate系列的区别(p系列和mate系列拍照)

  • iphone低电量模式有什么用(iphone低电量模式充电好不好)

    iphone低电量模式有什么用(iphone低电量模式充电好不好)

  • 手机卡号不用了不去注销可以吗(手机卡号不用了会自动销户吗)

    手机卡号不用了不去注销可以吗(手机卡号不用了会自动销户吗)

  • 爱奇艺我的片段在哪里找(爱奇艺视频片段)

    爱奇艺我的片段在哪里找(爱奇艺视频片段)

  • 手机怎么更新(手机怎么更新版本)

    手机怎么更新(手机怎么更新版本)

  • wps文字怎么打印(wps文字怎么打印满A4)

    wps文字怎么打印(wps文字怎么打印满A4)

  • wasal00是什么型号手机(Wasal00是什么型号)

    wasal00是什么型号手机(Wasal00是什么型号)

  • wps填空题的横线怎么打(wps填空的横线怎么弄)

    wps填空题的横线怎么打(wps填空的横线怎么弄)

  • 快手黄钻怎么提现比例(快手黄钻怎么提现苹果手机)

    快手黄钻怎么提现比例(快手黄钻怎么提现苹果手机)

  • 洋淘秀什么意思(淘宝洋淘秀对买家有啥好处)

    洋淘秀什么意思(淘宝洋淘秀对买家有啥好处)

  • 苹果x有没有抬头灯(苹果x有没有抬屏亮屏)

    苹果x有没有抬头灯(苹果x有没有抬屏亮屏)

  • 苹果x变卡了怎么办啊(苹果x变卡了怎么解决)

    苹果x变卡了怎么办啊(苹果x变卡了怎么解决)

  • 小米手环4标准版支持小爱同学吗(小米手环4标准版功能)

    小米手环4标准版支持小爱同学吗(小米手环4标准版功能)

  • 手机长时间不用充不上电怎么回事(手机长时间不用电池会不会坏掉)

    手机长时间不用充不上电怎么回事(手机长时间不用电池会不会坏掉)

  • 保姆级高通AEC9调试指南(看完可解决80%AE相关问题)(高通 adc)

    保姆级高通AEC9调试指南(看完可解决80%AE相关问题)(高通 adc)

  • JS实现数组去重的八种方法(实用)(js 数组去重的四种方法)

    JS实现数组去重的八种方法(实用)(js 数组去重的四种方法)

  • 航天税务软件
  • 借款合同印花税怎么申报
  • 给对方汇钱
  • 小规模纳税人运输费计入什么科目
  • 公司费用计入什么科目
  • 职工教育经费能结转几年
  • 有营业执照有什么好处吗?
  • 销售自产设备税率
  • 应计未计成本税前扣除年限
  • 材料采购成本差异属于什么科目
  • 买商品送购物券合法吗
  • 减免附加税还要计提吗
  • 选择纳税人身份考虑的因素
  • 退休人员返聘后辞退怎样补偿
  • 变动成本主要包括
  • 销售电梯并安装如何缴纳增值税
  • 推广服务费收入如何核算成本
  • 即征即退和先征后退适用范围
  • SQL Server2005、2008如何彻底删除卸载并重新安装?
  • 小规模纳税人减征额怎么计算
  • 金税卡服务费抵扣政策
  • windowsserver2019安装教程
  • 银行存款收款凭证属于什么凭证
  • PHP:session_save_path()的用法_Session函数
  • 贷款发生减值
  • echart怎么用
  • 公转私备注用途
  • 制造费用属于期间费用期末一定无余额吗
  • 会计记账的内容
  • 限售股转让个人所得税退税
  • 芒通,法国 (© Flavio Foglietta/Getty Images)
  • 厂房的设计审查要求
  • 购买固定资产后如何处理
  • 华硕自带win10系统
  • 应收票据计提利息
  • vuex和bus
  • btrfs 读取
  • php无限级分销
  • php access_token
  • php源码 数据库
  • 增值税专用发票和普通发票的区别
  • 应收利息的会计处理方法
  • 职工福利费怎么处理
  • 银行承兑汇票贴现分录
  • 四舍五入 vb
  • 劳务费发票怎么入账
  • php不支持mysql
  • 税金及附加如何预测
  • 无形资产加计扣除怎么算举例
  • 暂估入库跨年账务危险
  • 研发费用加计扣除新税收政策2023
  • 流动资产属于经营资产还是得经营资产
  • 偿债基金作用
  • 工会赞助费
  • 暂估费用的账务处理管理
  • 怎样理解
  • 去年的账科目记错了怎么办
  • 无工资支出企业账务处理
  • 厂家给的促销费可以退吗
  • mysql 创建root用户和普通用户及修改删除功能
  • 被遗忘的战役
  • mysql如何实现主从复制的具体流程
  • 安装fedora33
  • u盘安装win8系统教程
  • 苹果电脑如何缩小屏幕显示
  • Linux磁盘分区的作用
  • 2019谷歌浏览器
  • window 删除服务
  • centos查看具体版本
  • shell脚本的fi
  • 狗刨教学视频新手入门
  • jquery中什么方法用于模拟光标悬停事件
  • [置顶]游戏名:chivalry2
  • jquery原理解析
  • 实例分析法名词解释
  • 手表不贵比较好的品牌
  • 完税凭证验证码
  • 怎么打印个人所得税扣缴申报表
  • 企业2017年
  • 地税可以跨区交吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设