连接mysql数据库

  1. 数据库准备

    1. 如果连接本机数据库,mysql安装及配置可参考https://www.cnblogs.com/feizisy/p/11882521.html
    2. 如果连接阿里云RDS,需要阿里云工作台-数据安全性-白名单内添加外网IP

      白名单设置:

      127.0.0.1 不允许任何IP访问

      0.0.0.0/0 允许任何IP访问
  2. 创建数据库

    1. 本机:

      create database your_database_name
    2. 阿里云:阿里云工作台-数据库管理-创建数据库

  3. yourprojectname/settings.py 配置数据库

    # Database
    # https://docs.djangoproject.com/en/2.2/ref/settings/#databases DATABASES = {
    'default': dict(ENGINE='django.db.backends.mysql',
    HOST='your_host',
    #本机数据库,使用127.0.0.1
    #阿里云数据库,使用阿里云工作台-数据库连接-外网地址
    PORT='3306',
    NAME="your_database_name",
    USER='your_username',
    PASSWORD='your_password')
    }
  4. yourprojectname/init.py 下更改pymysql驱动,原默认为mysqldb(python3不再支持)

    import pymysql
    pymysql.install_as_MySQLdb()
  5. yourappname/models.py 创建数据库表

    from django.db import models
    
    """
    用户表
    """ class User(models.Model):
    username = models.CharField(verbose_name="用户名", max_length=20, unique=True, null=True)
    status = models.CharField(verbose_name="用户状态", max_length=4, null=True,help_text="0:已删除;1:使用中",default=1)
    iphone = models.CharField(verbose_name="手机号", max_length=11, unique=True, null=True)
    email = models.EmailField(verbose_name="邮箱", max_length=20, unique=True)
    signature = models.TextField(verbose_name="签名", max_length=500)
    createtime = models.DateTimeField(verbose_name="创建时间", auto_now=True) def __str__(self):
    return self.realname
  6. 数据库同步,终端执行,中间可能会遇到部分问题,参考https://www.cnblogs.com/feizisy/p/11847996.html

     python manage.py makemigrations
    python manage.py migrate #创建数据库表
  7. 迁移完成,可以在终端执行show tables,或者阿里云官网或navicat客户端查看django自带的一些表和你自己创建的User表

  8. 插入一条数据吧,在你的User表里,命令插入或者后面admin后台页面插入

  9. #如果命令插入的时候遇到更新中文字符,编码问题,三层更改为utf8
    
    alter database hf character set utf8;
    alter table auth_user default character set utf8;
    alter table auth_user change signature signature varchar(500) character set utf8;

models详细的数据操作

from yourappname.models import User
from datetime import datetime # 创建一个用户
>>> User.objects.create(username = "仙女",status = "1", iphone = "18832288888", email = "feizisy@126.com", signature = "今天也要开心哟", createtime = datatime(2019,11,22,20,58)) # 查询User中所有的对象列表
>>> User.objects.all()
<QuerySet [User:仙女]>
# 查询User中符合条件的对象列表
>>> User.objects.filter(username = "仙女")
# 查询符合条件的对象
>>> User.objects.get(id=1)
<User:仙女>
>>> User.objects.get(username__startswith='仙')
<User:仙女>
>>> User.objects.get(username__contains='女')
<User:仙女>
>>> User.objects.get(id=2)
Traceback (most recent call last):
...
DoesNotExist: User matching query does not exist. # 更新数据
>>> r = User.objects.get(id=1)
>>> r.username = "大仙女"
>>> r.save()
# 打印查看
>>> r.username
大仙女 # 删除该条数据
>>> r.delete()

pymysql的补充操作

import pymysql

# 连接数据库
conn = connect{
host = "127.0.0.1"
user = "root"
password = "the password of root"
db = "the name of the database"
charset = "the charset of the database"
cursorclass = cursors.DicCursor
} try:
# 获取数据库操作游标
with conn.cursor() as cursor:
sql = "select * from User where username = '仙女'"
# 执行SQL语句
cursor.execute(sql)
# 提交数据库执行
cursor.commit()
result = cursor.fetchone()
print(result)
finally:
# 关闭连接
conn.close()

配置admin后台

  1. 创建管理员账号

    python manage.py createsuperuser
  2. 运行项目

    python manage.py runserver 127.0.0.1:8001
  3. 可以在yourprojectname/settings.py下更改默认语言

    LANGUAGE_CODE = 'zh-hans'
  4. 访问 http://127.0.0.1:8001/admin/,用上面设置的用户名和密码登录

配置admin菜单视图

  1. yourappname/admin.py 下可定义admin相关菜单视图

    from django.contrib import admin
    from yourappname.models import * # Register your models here. class Useradmin(admin.ModelAdmin):
    list_display = ['id', 'username', 'iphone', 'email', 'signature','status'] #列表
    search_fields = ['username'] #搜索栏 admin.site.register(User, Useradmin) #注册模型
  2. 刷新admin后台登录页面,点击你的user表进入,你可以看到

002-Django数据库及后台admin配置的更多相关文章

  1. Django自带后台admin的使用配置

    Django自带后台使用配置参考官网地址:https://docs.djangoproject.com/en/1.11/ref/contrib/admin/ ,本文章值是介绍简单配置,如果需要详细内容 ...

  2. Django自带后台管理配置

    Django自带后台管理的配置 创建项目和应用 修改配置文件 数据库配置 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql' ...

  3. Django自带后台使用配置

    参考官网地址:https://docs.djangoproject.com/en/1.11/ref/contrib/admin/ ,本文章值是介绍简单配置,如果需要详细内容可以查阅官方文档 自动管理界 ...

  4. 14.Django自带的admin配置

    admin有自己的默认显示,要自定义显示的样式,一般需要自己定义一个类,在自己定义的类里进行相应的设置,然后,把自己的类交给装饰器 交给装饰器的方法有两种: 1.@admin.register(Pub ...

  5. 关于django访问默认后台admin的时候提示403错误,

    Forbidden (403) CSRF verification failed. Request aborted. You are seeing this message because this ...

  6. django之创建第9个项目-管理后台admin

    django之创建第9个项目-管理后台admin配置 1.配置setting文件INSTALLED_APPS = (    'django.contrib.auth',    'django.cont ...

  7. django+x-admin管理后台模板开发管理后台案例(设计部分)

    使用django+x-admin管理后台模板搭建管理后台 一.环境需求 1.django:3.1 2.python:3.7 3.x-admin:2.2 4.pycharm:2020.3.2 5.ubu ...

  8. django数据库读写分离

    django数据库读写分离 1. 配置数据库 settings.py文件中 用SQLite: DATABASES = { 'default': { 'ENGINE': 'django.db.backe ...

  9. 万里长征第二步——django个人博客(第五步 ——配置后台admin)

    在urls.py文件中配置admin路径 from django.conf.urls import url from django.contrib import admin from blog.vie ...

随机推荐

  1. Spring的新注解

    1 @Configuration 1.1 作用 用于指定当前类是一个Spring的配置类,当创建容器的时候会从该类上加载注解.获取容器的时候需要使用AnnotationApplicationConte ...

  2. cm日志哪里看

    root@d001:/home/centos# find / |grep cloudera-scm-agent.log/opt/cm-5.13.0/log/cloudera-scm-agent/clo ...

  3. Vue文件路径引入

  4. kafka伪分布式安装(2.12版)

    1.下载并解压. tar -xvf  kafka_2.12-1.0.0.tgz 2.进入config目录修改server.properties文件. log.dirs=/tmp/kafka-logs ...

  5. 【leetcode】LCP 1. Guess Numbers

    题目如下: 小A 和 小B 在玩猜数字.小B 每次从 1, 2, 3 中随机选择一个,小A 每次也从 1, 2, 3 中选择一个猜.他们一共进行三次这个游戏,请返回 小A 猜对了几次? 输入的gues ...

  6. GO语言学习笔记5-defer的使用

    1. 什么是defer defer是Go语言提供的一种用于注册延迟调用的机制:让函数或语句可以在当前函数执行完毕后(包括通过return正常结束或者panic导致的异常结束)执行. 2. defer的 ...

  7. CSS自适应布局

    目标效果: 缩小浏览器之后 在<head>最前面引入flexible.js <head> ... <script type="text/javascript&q ...

  8. sqli-labs(33)

    0X01构造闭合 发现‘ 被过滤了 那么 宽字节绕过 ?id=-%df%%20union%20,database(),%

  9. 【Python】学习笔记二:基本数据类型

    变量 python的变量不需要提前声明,可以直接输入: >>> str = 'oliver' 此时,str已经被赋值字符串oliver,在赋值之前并没有提前定义与事先声明 打印值 & ...

  10. mysql workbench中PK,NN,UQ,BIN,UN,ZF,AI字段类型标识说明

    PK:primary key 主键 NN:not null 非空 UQ:unique 唯一索引 BIN:binary 二进制数据(比text更大) UN:unsigned 无符号(非负数) ZF:ze ...