Express_mySQL_Ts 的整合

Node_Express_mySQL_Ts 的整合

  • 桌面新建文件夹express_mysql_ts

  • 初始化项目:npm init -y

    在这里插入图片描述

  • 安装一些需要的第三方模块npm i mysql2 express multer typescript cors ts-node-dev @types/node

    在这里插入图片描述

  • package.json中配置脚本

    {
      "name": "express_mysql_ts",
      "version": "1.0.0",
      "description": "",
      "main": "index.js",
      "scripts": {
        "start": "ts-node-dev ./src/app.ts"
      },
      "keywords": [],
      "author": "",
      "license": "ISC",
      "dependencies": {
        "cors": "^2.8.5",
        "express": "^4.18.1",
        "multer": "^1.4.5-lts.1",
        "mysql2": "^2.3.3",
        "ts-node-dev": "^2.0.0",
        "typescript": "^4.7.3"
      }
    }
    
  • 在根目录下新建文件夹src,在文件夹src下面新建文件夹app.ts作为入口文件。

  • 搭建项目的目录结构

    在这里插入图片描述

  • 首先打开Navicat Premium数据库开发工具,新建数据库mall

    use mall;
    
    CREATE TABLE `user` (
    id INT PRIMARY KEY AUTO_INCREMENT,
    username VARCHAR(20),
    `password` VARCHAR(20),
    nickName VARCHAR(20),
    age INT,
    birthday TIMESTAMP DEFAULT CURRENT_TIMESTAMP
    )
    
    INSERT INTO `user` SET username = 'admin',password = '123456',nickname = '张三',age = 18;
    INSERT INTO `user` SET username = 'lisi',password = '123456',nickname = '李四',age = 18;
    INSERT INTO `user` SET username = 'wangwu',password = '123456',nickname = '王五',age = 18;
    INSERT INTO `user` SET username = 'zhaoliu',password = '123456',nickname = '赵六',age = 18;
    
    SELECT * FROM `user`;
    
  • config文件夹下新建db.ts文件夹

    // config/db.ts
    
    export default {
      host: "localhost",
      port: 3306,
      user: "root",
      password: "123456",
      database: "mall",
    };
    
  • util文件夹下面新建文件index.ts(封装数据库操作语句)

    import { createConnection } from "mysql2";
    import config from "../config/db";
    
    // 创建数据库连接
    const connection = createConnection(config);
    
    export default class DBUtil {
      // 封装通用的数据库操作语句
      static query(
        sql: string,
        params?: any | any[] | { [param: string]: any }
      ): Promise<any> {
        // 通过Promise返回操作数据库的结果
        return new Promise<unknown>((resolve, reject) => {
          // 通过数据库连接对象执行sql语句
          connection.query(sql, params, (err, result, fields) => {
            // 判断sql执行有没有错误
            if (err) {
              // 失败
              reject(err);
            } else {
              // 成功
              resolve(result);
            }
          });
        });
      }
    }
    
  • router文件夹下面新建user.ts

    import * as express from "express";
    import UserService from "../service/user";
    
    const { queryAll, queryOne, save, del, edit } = new UserService();
    
    // 创建路由对象
    const userRouter = express.Router();
    
    // 查询所有
    userRouter.get("/", queryAll);
    // 根据id查询 单个
    userRouter.get("/:id", queryOne);
    // 添加
    userRouter.post("/", save);
    // 根据id删除
    userRouter.delete("/:id", del);
    // 修改
    userRouter.patch("/:id", edit);
    
    export default userRouter;
    
  • service文件夹下面新建user.ts

    import UserController from "../controller/user";
    
    const { queryAll, queryOne, save, del, edit } = new UserController();
    
    export default class UserService {
      // 查询所有
      async queryAll(request, response): Promise<void> {
        const { page } = request.query;
        // 开始位置
        let startPage = 0;
        if (page && page != 'undefined') {
          // 一页数量 10
          startPage = (page - 1) * 10;
        }
        const res = await queryAll([startPage, 10]);
        response.send(res);
      }
    
      // 根据id查询 单个
      async queryOne(request, response): Promise<void> {
        const { id } = request.params;
        const [res] = await queryOne([id]);
        response.send(res);
      }
    
      // 保存 添加
      async save(request, response): Promise<void> {
        const body = request.body;
        const { insertId } = await save(body);
        response.send(insertId ? "添加成功" : "添加失败");
      }
    
      // 根据id删除
      async del(request, response): Promise<void> {
        const { id } = request.params;
        const res = await del([id]);
        response.send(res);
      }
    
      // 修改
      async edit(request, response): Promise<void> {
        const body = request.body;
        const { id } = request.params;
        const { affextedRoes } = await edit([body, id]);
        response.send(affextedRoes ? "修改成功" : "修改失败");
      }
    }
    
  • controller文件夹下面新建user.ts

    import DBUtil from "../util";
    
    export default class UserController {
      /**
       * 查询全部
       * @param params
       * @returns
       */
      queryAll(params: any) {
        return DBUtil.query("select * from user limit ?,?", params);
      }
      /**
       * 根据id查询 单个
       * @param params
       */
      queryOne(params: any) {
        return DBUtil.query("select * from user where id = ?", params);
      }
      /**
       * 根据id删除
       * @param params
       * @returns
       */
      del(params: any) {
        return DBUtil.query("delete from user where id = ?", params);
      }
    
      // 保存 添加
      save(params: any) {
        return DBUtil.query("insert into user set ?", params);
      }
    
      // 修改
      edit(params: any) {
        return DBUtil.query("update user set ? where id =?", params);
      }
    }
    
  • 最后根据Postman接口测试工具一一测试,无误

PCI Express Base 6 是指PCI Express的第六个版本,它是一种用于计算机系统的高性能串行总线接口标准。PCI Express(简称PCIe)是一种用于扩展计算机系统总线带宽和连接的标准,它取代了传统的PCI(Peripheral Component Interconnect,外围组件互连)标准。 PCI Express Base 6 的版本号代表了其在PCIe标准发展历程中的进化。每个PCIe版本的发布都带来了一系列新的特性和改进,以满足不断升级的计算机系统需求。 PCI Express Base 6 版本的特性通常包括更高的数据传输速率、更多的通道数量、更低的延迟和更高的功率管理功能。通过提高数据传输速率,PCIe可以更快地传输数据和命令,从而提升系统性能和响应速度。增加通道数量可以支持更多的设备同时进行数据传输,提高系统的扩展性和灵活性。减小延迟可以缩短指令传输时间,更快地响应系统的操作。而更强大的功率管理功能可以有效地控制设备的能耗,提高系统的能效。 PCI Express Base 6 还可能引入一些新的技术和协议,以满足新兴的应用需求。例如,支持内存扩展技术,允许计算机系统通过PCIe接口访问更大容量的内存。此外,PCIe还可能支持新的图形接口标准,提供更高的图形处理性能。 总而言之,PCI Express Base 6 是一种通用的高性能串行总线接口标准,用于扩展计算机系统的带宽和连接能力,并提供更快、更稳定和更高效的数据传输。通过不断升级和改进,PCIe标准可满足不断变化的计算机系统需求,并促进数字化时代各个领域的发展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值