当前位置: 首页 > news >正文

新建Django项目+本地Mysql数据库demo

1、当前路径下指定虚拟环境激活

a123456@zbMacBook-Pro demo % source /Users/a123456/pyenv/django_xb//bin/activate
(django_xb) a123456@zbMacBook-Pro demo % pip list
Package            Version
------------------ ----------
asgiref            3.11.0
certifi            2025.11.12
cffi               2.0.0
charset-normalizer 3.4.4
cryptography       46.0.3
Django             3.2.16
idna               3.11
pip                25.3
pycparser          2.23
PyMySQL            1.0.2
pytz               2025.2
requests           2.32.5
setuptools         65.5.1
sqlparse           0.5.5
urllib3            2.6.2
wheel              0.38.4

2、执行 Django 项目创建命令,<project_name>替换为你的项目名称

django-admin startproject <project_name>
(django_xb) a123456@zbMacBook-Pro demo % django-admin startproject django_xb

3、Django项目下,新建模块

python manage.py startapp tools

3.1 目录结构

tools/
├── __init__.py       # 标识该目录为Python包
├── admin.py          # 配置Django后台管理该app的模型
├── apps.py           # app的核心配置文件(包含app元数据)
├── migrations/       # 存储模型迁移文件(数据库同步相关)
│   └── __init__.py
├── models.py         # 定义app的数据模型(对应数据库表)
├── tests.py          # 编写该app的单元测试用例
└── views.py          # 编写该app的视图逻辑(处理请求、返回响应)

4、注册app+配置数据库链接,找到主项目目录下的setting.py文件

# Application definition
INSTALLED_APPS = ['django.contrib.admin','django.contrib.auth','django.contrib.contenttypes','django.contrib.sessions','django.contrib.messages','django.contrib.staticfiles','tools'
]# Database
DATABASES = {'default': {'ENGINE': 'django.db.backends.mysql','NAME': 'django_demo',"USER": 'root',"PASSWORD": "123456","HOST": 'localhost', "PORT": 3306,"CHARSET": "UTF-8"},
}

注意:这时候启动项目有个坑,启动django项目的时候报错

# python manage.py runserver  0.0.0.0:8080
Connected to pydev debugger (build 231.9011.38) Watching for file changes with StatReloader Traceback (most recent call last):File "/Users/a123456/pyenv/django_xb/lib/python3.11/site-packages/django/db/backends/mysql/base.py", line 15, in <module>import MySQLdb as Database ModuleNotFoundError: No module named 'MySQLdb' The above exception was the direct cause of the following exception:

解决方法:找到主项目下的初始化文件__init__.py

import pymysql
# 让 Django 把 pymysql 当作 MySQLdb 来使用
pymysql.install_as_MySQLdb()

5、新模块定义数据模型 models.py

from django.db import models# Create your models here.   
class Emp(models.Model):id = models.CharField(max_length=50, primary_key=True, verbose_name="主键ID")name = models.CharField(max_length=255, verbose_name="员工名称")age = models.IntegerField(default=0, verbose_name="年龄")class Meta:db_table = 'emp'verbose_name = "员工表"

5.1 生成迁移文件 

# 生成迁移文件
python manage.py makemigrations
# 指定模块生成迁移文件
python manage.py makemigrations tools
# 执行迁移
python manage.py migrate

6、编写视图函数 views.py

from django.http import JsonResponse
from django.views.decorators.csrf import csrf_exempt
from django.views.decorators.http import require_GET
from .models import Emp@csrf_exempt
@require_GET
def emp_list(request):"""获取员工列表"""emps = Emp.objects.all().values()return JsonResponse({'code': 0,'msg': "员工列表",'data': list(emps)})

7、新模块下创建urls.py

from django.urls import path
from .views import emp_list
app_name = 'tools'
urlpatterns = [path('emp/list', emp_list, name="emp_list"),
]

8、将路由配置到主项目下的urls

from django.contrib import admin
from django.urls import path,includeurlpatterns = [path('admin/', admin.site.urls),path('tools/', include('tools.urls')),#新模块路由配置到这里
]

9、启动项目

(django_xb) a123456@zbMacBook-Pro django_zb % python manage.py runserver  0.0.0.0:8080
Watching for file changes with StatReloader
Performing system checks...System check identified no issues (0 silenced).
December 31, 2025 - 06:52:22
Django version 3.2.16, using settings 'django_zb.settings'
Starting development server at http://0.0.0.0:8080/
Quit the server with CONTROL-C.

10、接口访问

image

 11、学习后总结,待补充

  

http://www.rkmt.cn/news/187388.html

相关文章:

  • 揭秘cxx-qt底层机制:如何实现C++与Rust无缝通信并提升开发效率
  • 一文掌握DataFlow!这款超好用的LLM数据处理框架,建议收藏!
  • DiskInfo显示TensorFlow镜像块设备详细信息
  • 用 Python 轻松剖析 GPU 性能:NVIDIA nsight-python 包来帮忙!
  • 收藏!35岁程序员破局指南:从被裁到AI高薪,这篇实操手册帮你踩准风口
  • 写可靠安全的 CUDA 代码:编码规范 + 自动化检查的“双保险”
  • 2026仿石漆厂家最新推荐:上海岩首何以领跑液态石材新赛道? - 深度智识库
  • 2025天然蛋白/有机金属试剂/神经肽品牌TOP5权威推荐:阿拉丁国产科研试剂破局升级 - myqiye
  • 微信立减金怎么变成现金,推荐靠谱平台 - 京回收小程序
  • SSH批量管理多个TensorFlow 2.9镜像节点
  • Python自动整理音乐文件:按艺术家和专辑分类歌曲
  • DiskInfo分析TensorFlow数据预处理阶段IO性能
  • PyTorch安装教程GPU推理性能与TensorFlow实测对比
  • Conda环境克隆快速复制TensorFlow开发配置
  • GitHub Wiki构建TensorFlow项目文档知识库
  • 胶原蛋白粉哪个牌子好 2026权威临床数据指南 - 博客万
  • 你还在手写重复代码?,用C++26静态反射实现全自动序列化(效率提升10倍)
  • 大模型Token限流机制保障系统稳定性
  • 实现消防主机Modbus转IEC 61850接入智能消防监控平台项目案例 - vfbox
  • 2025年金丝绒瓷砖源头工厂排行榜,金丝绒瓷砖厂家哪家多人选择测评推荐 - 工业品牌热点
  • 基于TensorFlow-v2.9的深度学习开发环境配置指南
  • 大模型Token审计日志追踪API调用行为
  • Docker安装常见问题排查:TensorFlow镜像启动失败解决办法
  • Conda创建独立环境隔离不同TensorFlow项目依赖
  • 如何写出爆款技术博客吸引TensorFlow目标用户
  • Git Cherry-pick将特定提交应用到TensorFlow分支
  • 面向随钻测量系统的高可靠性200℃级AC-DC电源技术解析
  • 2025年山西口碑好的技师学院排名,技师学院国际合作项目全解析 - 工业设备
  • 2026年全球飞秒激光器厂商竞争格局:行业标杆企业实力生产商厂家推荐 - 品牌推荐大师1
  • 2025年金丝绒瓷砖靠谱厂家推荐:金丝绒瓷砖源头厂家哪家规模大? - 工业品牌热点