002-Django数据库及后台admin配置
连接mysql数据库
数据库准备
- 如果连接本机数据库,mysql安装及配置可参考https://www.cnblogs.com/feizisy/p/11882521.html
- 如果连接阿里云RDS,需要阿里云工作台-数据安全性-白名单内添加外网IP
白名单设置:
127.0.0.1 不允许任何IP访问
0.0.0.0/0 允许任何IP访问
创建数据库
本机:
create database your_database_name
阿里云:阿里云工作台-数据库管理-创建数据库
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')
}
yourprojectname/init.py 下更改pymysql驱动,原默认为mysqldb(python3不再支持)
import pymysql
pymysql.install_as_MySQLdb()
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
数据库同步,终端执行,中间可能会遇到部分问题,参考https://www.cnblogs.com/feizisy/p/11847996.html
python manage.py makemigrations
python manage.py migrate #创建数据库表
迁移完成,可以在终端执行show tables,或者阿里云官网或navicat客户端查看django自带的一些表和你自己创建的User表
插入一条数据吧,在你的User表里,命令插入或者后面admin后台页面插入
#如果命令插入的时候遇到更新中文字符,编码问题,三层更改为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后台
创建管理员账号
python manage.py createsuperuser
运行项目
python manage.py runserver 127.0.0.1:8001
可以在yourprojectname/settings.py下更改默认语言
LANGUAGE_CODE = 'zh-hans'

配置admin菜单视图
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) #注册模型
刷新admin后台登录页面,点击你的user表进入,你可以看到

002-Django数据库及后台admin配置的更多相关文章
- Django自带后台admin的使用配置
Django自带后台使用配置参考官网地址:https://docs.djangoproject.com/en/1.11/ref/contrib/admin/ ,本文章值是介绍简单配置,如果需要详细内容 ...
- Django自带后台管理配置
Django自带后台管理的配置 创建项目和应用 修改配置文件 数据库配置 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql' ...
- Django自带后台使用配置
参考官网地址:https://docs.djangoproject.com/en/1.11/ref/contrib/admin/ ,本文章值是介绍简单配置,如果需要详细内容可以查阅官方文档 自动管理界 ...
- 14.Django自带的admin配置
admin有自己的默认显示,要自定义显示的样式,一般需要自己定义一个类,在自己定义的类里进行相应的设置,然后,把自己的类交给装饰器 交给装饰器的方法有两种: 1.@admin.register(Pub ...
- 关于django访问默认后台admin的时候提示403错误,
Forbidden (403) CSRF verification failed. Request aborted. You are seeing this message because this ...
- django之创建第9个项目-管理后台admin
django之创建第9个项目-管理后台admin配置 1.配置setting文件INSTALLED_APPS = ( 'django.contrib.auth', 'django.cont ...
- 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 ...
- django数据库读写分离
django数据库读写分离 1. 配置数据库 settings.py文件中 用SQLite: DATABASES = { 'default': { 'ENGINE': 'django.db.backe ...
- 万里长征第二步——django个人博客(第五步 ——配置后台admin)
在urls.py文件中配置admin路径 from django.conf.urls import url from django.contrib import admin from blog.vie ...
随机推荐
- 最简单的Android项目(NDK命令行编译)
Android的NDK编程需要下载NDK编译环境,可以从官网下载window64位版,然后解压到任意目录即可. NDK的实现其实是利用里Java的jni方法,所以前期的步骤可以参考jni的实现方法,只 ...
- exe远程注入线程xp
进程删除不了 某目录下txt ini config 无法修改
- spring事务配置,声明式事务管理和基于@Transactional注解的使用(转载)
原文地址:http://blog.csdn.net/bao19901210/article/details/41724355 事务管理对于企业应用来说是至关重要的,好使出现异常情况,它也可以保证数据的 ...
- 【洛谷P1417】烹调方案 贪心+背包dp
题目大意:一共有 n 件食材,每件食材有三个属性,ai,bi和ci,如果在t时刻完成第i样食材则得到ai-t*bi的美味指数,用第i件食材做饭要花去ci的时间.众所周知,gw的厨艺不怎么样,所以他需要 ...
- NETCONF
NETCONF协议(Network Configration Protocol) NETCONF是一个基于XML的交换机配置接口,用于替代CLI.SNMP等配置交换机. 本质上来说,NETCONF就是 ...
- 【NOIP2016提高A组模拟8.17】(雅礼联考day1)Matrix
题目 分析 假设,我们从\(F_{i,2}\)出发,那么对\(F_{n,n}\)的贡献就是\(某个系数乘以a^{n-i}b^{n-1}r_i\): 同理,如果从\(F_{2,i}\)出发,那么对\(F ...
- npm 和 cnpm 区别
来源:https ://blog.csdn.net/shelly1072/article/details/51524029 NPM介绍: 说明:NPM(节点包管理器)是的NodeJS的包管理器,用于节 ...
- sh_07_火车站安检
sh_07_火车站安检 # 定义布尔型变量 has_ticket 表示是否有车票 has_ticket = True # 定义整型变量 knife_length 表示刀的长度,单位:厘米 knife_ ...
- jenkins启动tomcat失败的解决方法
在网上看了都说是加BUILDID, 但是我加了之后,还是启动不成功. 执行了下面2个步骤: 1.在远程服务器的启动脚本里,用nohup来运行启动命令 nohup ./*.start.${prg}.sh ...
- go语言系列--输出正弦函数
实验所用到的标准库和包 库与包之间的理解可以类比成:数据库种的库和表 库名 作用 image 常见图形格式的访问及生成 log 日志记录库 math 数学库 os 操作系统平台不依赖平台操作封装 查看 ...