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

宁波网站建设怎么样新的网络推广方式

宁波网站建设怎么样,新的网络推广方式,wordpress them8主题,网站建设的计划笔记为自我总结整理的学习笔记,若有错误欢迎指出哟~ 【Django专栏】 Django——django简介、django安装、创建项目、快速上手 Django——templates模板、静态文件、django模板语法、请求和响应 Django——连接mysql数据库 Django——连接mysql数据库 连接MySQL数据库…

笔记为自我总结整理的学习笔记,若有错误欢迎指出哟~

【Django专栏】
Django——django简介、django安装、创建项目、快速上手
Django——templates模板、静态文件、django模板语法、请求和响应
Django——连接mysql数据库

Django——连接mysql数据库

  • 连接MySQL数据库
    • 1.安装MySQL驱动程序
    • 2.创建数据库
    • 3.配置settings.py文件
    • 4.django操作表
      • django操作表语句与mysql语句的关系
      • 创建表
      • 修改表
      • 插入数据
      • 删除数据
      • 查询数据
      • 更新数据
    • 5.迁移数据库
      • 报错解决

连接MySQL数据库

ORM(Object-Relational Mapping)是一种编程技术,它允许开发者使用面向对象的方式来操作数据库,而不必直接编写SQL语句。在Django中,ORM是通过Django自带的django.db.models模块来实现的。

  • 创建、修改、删除数据库中的表【无法创建数据库】
  • 操作表中的数据

1.安装MySQL驱动程序

首先,确保你已经安装了适用于Python的MySQL驱动程序。可以使用pip命令来安装,例如:

pip install mysqlclient -i https://pypi.tuna.tsinghua.edu.cn/simple

在这里插入图片描述

2.创建数据库

需要在mysql中完成
在这里插入图片描述

3.配置settings.py文件

打开你的Django项目中的settings.py文件,找到DATABASES设置部分,并进行如下配置:

DATABASES = {'default': {'ENGINE': 'django.db.backends.mysql','NAME': 'your_database_name','USER': 'your_mysql_username','PASSWORD': 'your_mysql_password','HOST': 'localhost','PORT': '3306',}
}

确保将your_database_nameyour_mysql_usernameyour_mysql_password替换为你的MySQL数据库的名称、用户名和密码。

4.django操作表

django操作表语句与mysql语句的关系

在Django中,操作表的语句与直接在MySQL中执行的SQL语句有着密切的关系。Django的ORM(Object-Relational Mapping)提供了一种Pythonic的方式来操作数据库,它将Python代码翻译成对应的SQL语句,并执行这些SQL语句以实现数据库操作。

下面是一些常见的数据库操作,以及它们在Django ORM中的对应方式和在MySQL中的原生SQL语句:

创建表

Django ORM:

# 在models.py中定义模型
class UserInfo(models.Model):
name = models.CharField(max_length=64)
password = models.CharField(max_length=128)
age = models.IntegerField()

MySQL原生SQL:

CREATE TABLE application01_userinfo (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(64),
password VARCHAR(128),
age INT

使用Django的管理命令manage.py来执行数据库迁移操作,将模型映射到实际的数据库表。在命令行中执行以下命令:

python manage.py makemigrations  # 生成数据库迁移文件
python manage.py migrate  # 应用数据库迁移

修改表

新增一个列
两种选择:
在这里插入图片描述
1) 立即提供一次性默认值(将在该列具有null值的所有现有行上设置)
2) 退出,在models.py中添加一个默认值或允许为空

# 添加默认值
salary = models.IntegerField(default=5000)
# 允许为空
salary = models.IntegerField(null=True, blank=True)

在这里插入图片描述

插入数据

# 原生sql语句:insert into application01_userinfo(name, password, age) VALUES ('quanquan', '123', 18)
# UserInfo.objects.create(name=name, password=password, age=age)def register(request):# POST方式if request.method == 'POST':# 处理表单提交name = request.POST.get('name', '')password = request.POST.get('password', '')age = request.POST.get('age')# 构造上下文数据context = {'name': name,'password': password,'age': age,}# 往数据库插入数据UserInfo.objects.create(name=name, password=password, age=age)# 渲染模板并返回响应return render(request, 'result.html', context)else:# 显示表单页面return render(request, 'register.html')

register.html

<!DOCTYPE html>
<html>
<head><title>输入信息</title>
</head>
<body><h2>请输入您的信息</h2><form method="post" action="/register/">
<!--        {% csrf_token %} 是 Django 模板标记,用于防止跨站请求伪造(CSRF)攻击。-->
<!--        Django 要求所有 POST 的表单都要包含这个标记,以确保安全性。-->{% csrf_token %}<label for="name">姓名:</label><input type="text" id="name" name="name"><br><br><label for="password">密码:</label><input type="text" id="password" name="password"><br><br><label for="age">年龄:</label><input type="text" id="age" name="age"><br><br><input type="submit" value="提交"></form>
</body>
</html>

result.html

<!-- result.html -->
<!DOCTYPE html>
<html>
<head><title>提交结果</title>
</head>
<body><h2>提交结果</h2><p>您提交的信息如下:</p><p>姓名:{{ name }}</p><p>密码:{{ password }}</p><p>年龄:{{ age }}</p>
</body>
</html>

在这里插入图片描述
在这里插入图片描述

删除数据

# 删除数据
UserInfo.objects.filter(id=1).delete()
UserInfo.objects.all().delete()

查询数据

# 查询数据
data_list = UserInfo.objects.all()# data_list = [行对象,行对象,...,行对象]	QuerySet类型print(data_list)	
# <QuerySet [<UserInfo: UserInfo object (3)>, <UserInfo: UserInfo object (4)>]>for obj in data_list:print(obj.name,obj.password,obj.age)
# 圈圈 123456 20
# 圈圈1 123456 11

更新数据

# 更新 id 为 1 的记录的 name 和 age 字段
UserInfo.objects.filter(id=1).update(name='new_name', age=30)

Django的ORM会将我们的Python代码翻译成对应的SQL语句,并执行这些SQL语句以实现数据库操作。这种方式简化了数据库操作的复杂性,同时也提高了代码的可读性和可维护性。

5.迁移数据库

使用Django的管理命令manage.py来执行数据库迁移操作,将模型映射到实际的数据库表。在命令行中执行以下命令:

python manage.py makemigrations  # 生成数据库迁移文件
python manage.py migrate  # 应用数据库迁移

Django 就会根据这个模型创建相应的 MySQL 表。假设你的应用名为 application01,模型名为userinfo,那么在 MySQL 数据库中就会生成一个名为 application01_userinfo的表
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

报错解决

报错:django.db.utils.NotSupportedError: MySQL 8 or later is required (found 5.7.26)
原因:django与mysql版本不兼容
解决方式:
1.升级mysql版本(SELECT VERSION() 我的版本是5.5.40),有点麻烦不想升级
2.降低django版本(需要先搜一下版本兼容情况)

pip uninstall django
pip install django==2.0 -i https://pypi.tuna.tsinghua.edu.cn/simple

http://www.ds6.com.cn/news/87898.html

相关文章:

  • 福州网站搭建网站排名查询平台
  • 网站300m是什么意思怎么把平台推广出去
  • 网站模板但没有后台如何做网站最新的疫情数据
  • 做网站都有那些步骤网络推广哪家好
  • 电子印章在线制作网站站长工具查询
  • 怎样在网站上做专栏seo综合查询工具有什么功能
  • 公司网站没做301怎么做301域名网
  • 做网站的搜索引擎如何制作网址
  • 番禺市桥网站建设公司网站地址ip域名查询
  • 网站做数据统计网站推广和seo
  • 哪个网站可以做字体大小寻找客户的12种方法
  • 一家专门做母婴的网站百度总部
  • 做网站的图片Pc端和手机端的区别哪家公司做seo
  • 巨野县建设局网站百度知道合伙人答题兼职
  • 做cpa用单页网站好还是百度网站快速优化
  • 在中国建设银行的网站上可以转账吗抖音seo优化
  • 济宁做公司网站关键词完整版免费听
  • 网站首页模板免费下载百度客服人工在线咨询
  • html网页模板简洁青岛seo服务
  • 广东源江建设集团有限公司网站网站设计的基本原则
  • 做商铺最好的网站全网品牌推广公司
  • 郑州网站制作企业网络营销的现状和发展趋势
  • 漂亮企业网站站长网站大全
  • 免费美食网站源码重庆百度推广开户
  • 鄂州商城网站建设最新新闻热点事件2022
  • 小型营销企业网站建设策划网络营销案例分析ppt
  • 商城源码免费下载优化seo教程技术
  • 莱芜口镇规划网站排名优化服务
  • 怎么用axure做h5网站百度推广关键词技巧定价
  • wordpress add_user_metaseo推广的常见目的有