Django之旅:第五节--Mysql数据库操作(一)

Django开发操作数据库更简单,内部提供了ORM框架

一、安装第三方模块

复制代码
pip install mysqlclient

注:最新的django框架需要使用mysqlclient模块,之前pymysql模块与django框架有编码兼容问题。

二、ORM

1、ORM可以帮助我们做两件事:

创建、修改、删除数据库中的表(不用写sql语句)(没有办法创建数据库)。

操作表中的数据(不用写sql语句)

2、创建数据库

2.1、启动Mysql服务

2.2、创建数据库

复制代码
create database 数据库名称 DEFAULT CHARSET utf8 COLLATE utf8_general_ci;

#操作数据库指令

#登录
mysql -u root(mysql用户名) -p

#查看数据库
show databases;

三、Django连接数据库

在setting.py文件中进行配置和修改

复制代码
DATABASES = {
    'default': {
        # 'ENGINE': 'django.db.backends.sqlite3',
        # 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
        
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'index_day',  # 数据库
        'USER': 'root',
        'PASSWORD': '12345678',
        'HOST': '127.0.0.1',  # mysql那台机器的ip
        'PORT': '3306',
    }
}

四、Django操作表

1、创建表(models.py文件中操作)

python 复制代码
from django.db import mmodels

class UserInfo(models.Model):
    name=models.CharFIeld(max_length=32)
    password=models.CharFIeld(max_length=64)
    age=models.IntegerFIeld()

"""
上面类等于以下sql语句
cerate table app项目名_userinfo(
    id bigint auto_increment primary key,
    name varchar(32),
    password varchar(64),
    age int
"""

完成以上,需要执行以下命令,生成表(app需要提前注册)

python 复制代码
python manage.py makemigrations
python manage.py migrate

2、删除表

python 复制代码
from django.db import mmodels

class UserInfo(models.Model):
    name=models.CharFIeld(max_length=32)
    password=models.CharFIeld(max_length=64)
    #age=models.IntegerFIeld()

注:只要把对应的类或者字段注销或者删除,在执行以下

python 复制代码
python manage.py makemigrations
python manage.py migrate

3、修改表

注:在修改表,添加字段如果表本身有数据,需要默认值,或者设置默认可以为空。

如果类里面,字段不设置默认值,在执行命令行代码时也会提示,属于默认值或者退出

python 复制代码
from django.db import mmodels

class UserInfo(models.Model):
    name=models.CharFIeld(max_length=32)
    password=models.CharFIeld(max_length=64)
    #age=models.IntegerFIeld()
    
    data=models.IntegerField(defaul=2)#新字段默认为值为2

    content=models.IntegerField(null=True,blank=True)#新字段默认为值为空
    

再次执行该命令:

python 复制代码
python manage.py makemigrations
python manage.py migrate

五、总结:

在以后的开发中如果想要对表结构进行调整:

在models.py文件中操作类就可以了

在执行命令:

python 复制代码
python manage.py makemigrations
python manage.py migrate
相关推荐
特立独行的猫a7 分钟前
PostgreSQL客户端工具介绍:从性能测试到跨平台管理
数据库·docker·postgresql·客户端·pgadmin4
微爱帮监所写信寄信8 分钟前
微爱帮监狱写信寄信小程序:MySQL核心日志与备份恢复安全架构
数据库·mysql·小程序·邮局·监狱寄信·挂号信·邮政
isNotNullX43 分钟前
数据迁移怎么做?有什么好用的数据库迁移工具推荐吗?
数据库·数字化·数据迁移·企业管理
云老大TG:@yunlaoda3601 小时前
华为云国际站代理商DAS的跨境合规适配的应用场景有哪些?
网络·数据库·华为云
3824278271 小时前
python3网络爬虫开发实战 第二版:绑定回调
开发语言·数据库·python
BIBI20491 小时前
Windows 上配置 Nacos Server 3.x.x 使用 MySQL 5.7
java·windows·spring boot·后端·mysql·nacos·配置
wniuniu_1 小时前
ceph的参数
java·数据库·ceph
一只专注api接口开发的技术猿2 小时前
智能决策数据源:利用 1688 商品详情 API 构建实时比价与供应链分析系统
大数据·前端·数据库
山峰哥2 小时前
SQL查询优化秘籍:从Explain分析到性能飞跃
开发语言·数据库·sql·oracle·性能优化·系统优化
刘一说2 小时前
MySQL 版本演进全景图:从 5.6 到 8.4 的技术变革与行业实践
数据库·mysql