您的位置:首页 > 文旅 > 美景 > 江西赣州疫情通报_电影网站免费建设_外贸网络推广经验_淘宝推广引流方法有哪些

江西赣州疫情通报_电影网站免费建设_外贸网络推广经验_淘宝推广引流方法有哪些

2025/4/3 12:59:59 来源:https://blog.csdn.net/cf8833/article/details/146478827  浏览:    关键词:江西赣州疫情通报_电影网站免费建设_外贸网络推广经验_淘宝推广引流方法有哪些
江西赣州疫情通报_电影网站免费建设_外贸网络推广经验_淘宝推广引流方法有哪些

说明:
我计划用next.js+mysql实现增删改查
step1:sql

-- 用户表:存储用户基础信息
CREATE TABLE users (id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY COMMENT '用户唯一标识',username VARCHAR(50) NOT NULL UNIQUE COMMENT '用户名(唯一)',email VARCHAR(100) NOT NULL UNIQUE COMMENT '邮箱(唯一)',created_at DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',updated_at DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间',status ENUM('active', 'banned', 'deleted') DEFAULT 'active' COMMENT '用户状态'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='用户表';

step2:db.js C:\Users\wangrusheng\PycharmProjects\untitled4\src\lib\db.js

import mysql from 'mysql2/promise';const pool = mysql.createPool({host: 'localhost',user: 'root',password: '123456',database: 'db_school',waitForConnections: true,connectionLimit: 10,queueLimit: 0
});export default pool;

step3:router.js C:\Users\wangrusheng\PycharmProjects\untitled4\src\app\api\users\route.js

import { NextResponse } from 'next/server';
import pool from '@/lib/db';// 获取所有用户或单个用户
export async function GET(request) {try {const { searchParams } = new URL(request.url);const id = searchParams.get('id');const connection = await pool.getConnection();if (id) {const [rows] = await connection.query('SELECT * FROM users WHERE id = ?',[id]);connection.release();return NextResponse.json(rows[0] || {});} else {const [rows] = await connection.query('SELECT * FROM users');connection.release();return NextResponse.json(rows);}} catch (error) {return NextResponse.json({ error: error.message },{ status: 500 });}
}// 创建新用户
export async function POST(request) {try {const { username, email, status = 'active' } = await request.json();if (!username || !email) {return NextResponse.json({ error: 'Missing required fields' },{ status: 400 });}const connection = await pool.getConnection();const [result] = await connection.query('INSERT INTO users (username, email, status) VALUES (?, ?, ?)',[username, email, status]);connection.release();return NextResponse.json({id: result.insertId,message: 'User created successfully'}, { status: 201 });} catch (error) {if (error.code === 'ER_DUP_ENTRY') {return NextResponse.json({ error: 'Username or email already exists' },{ status: 409 });}return NextResponse.json({ error: error.message },{ status: 500 });}
}// 更新用户
export async function PUT(request) {try {const { id, ...updateData } = await request.json();if (!id) {return NextResponse.json({ error: 'User ID required' },{ status: 400 });}const connection = await pool.getConnection();const [result] = await connection.query('UPDATE users SET ? WHERE id = ?',[updateData, id]);connection.release();if (result.affectedRows === 0) {return NextResponse.json({ error: 'User not found' },{ status: 404 });}return NextResponse.json({ message: 'User updated successfully' });} catch (error) {return NextResponse.json({ error: error.message },{ status: 500 });}
}// 删除用户
export async function DELETE(request) {try {const { searchParams } = new URL(request.url);const id = searchParams.get('id');if (!id) {return NextResponse.json({ error: 'User ID required' },{ status: 400 });}const connection = await pool.getConnection();const [result] = await connection.query('DELETE FROM users WHERE id = ?',[id]);connection.release();if (result.affectedRows === 0) {return NextResponse.json({ error: 'User not found' },{ status: 404 });}return NextResponse.json({ message: 'User deleted successfully' });} catch (error) {return NextResponse.json({ error: error.message },{ status: 500 });}
}

step4:postman

 获取所有用户http://localhost:3002/api/users[{"id": 1,"username": "张飞","email": "zhangfei@example.com","created_at": "2025-03-24T02:56:52.000Z","updated_at": "2025-03-24T02:56:52.000Z","status": "active"},{"id": 2,"username": "刘备","email": "liubei@example.com","created_at": "2025-03-24T02:56:52.000Z","updated_at": "2025-03-24T02:56:52.000Z","status": "active"},{"id": 3,"username": "关羽","email": "guanyu@example.com","created_at": "2025-03-24T02:56:52.000Z","updated_at": "2025-03-24T02:56:52.000Z","status": "active"}
]获取单个用户GET http://localhost:3000/api/users?id=1{"id": 1,"username": "张飞","email": "zhangfei@example.com","created_at": "2025-03-24T02:56:52.000Z","updated_at": "2025-03-24T02:56:52.000Z","status": "active"
}创建用户POST http://localhost:3000/api/users
Content-Type: application/json{"username": "john_doe","email": "john@example.com","status": "active"
}{"id": 4,"message": "User created successfully"
}更新用户PUT http://localhost:3000/api/users
Content-Type: application/json{"id": 1,"username": "new_username","email": "new@example.com"
}
{"message": "User updated successfully"
}删除用户DELETE http://localhost:3000/api/users?id=1{"message": "User deleted successfully"
}

step6:packages.json C:\Users\wangrusheng\PycharmProjects\untitled4\package.json

{"name": "untitled4","version": "0.1.0","private": true,"scripts": {"dev": "next dev --turbopack","build": "next build","start": "next start","lint": "next lint"},"dependencies": {"@heroicons/react": "^2.2.0","mysql2": "^3.14.0","next": "15.2.3","react": "^19.0.0","react-dom": "^19.0.0"},"devDependencies": {"@eslint/eslintrc": "^3","@tailwindcss/postcss": "^4","@types/node": "^20","@types/react": "^19","@types/react-dom": "^19","autoprefixer": "^10.4.21","eslint": "^9","eslint-config-next": "15.2.3","postcss": "^8.5.3","tailwindcss": "^4.0.15","typescript": "^5"}
}

总结:
1.就是一个基于nodejs弄出来的框架,写写api还可以,
2.千万别用来写界面,巨麻烦,我想弄个界面,对user表增删改查,居然让我创建一堆的文件
3.构建前端页面,比较慢,很麻烦,访问路由,居然需要自己手动拼接路径,体验感比angular差远了
3.总体来讲,我的评价是:写api不如fastapi,写界面不如angular,玩具一个
end

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com