web开发第四课数据库操作
来源:互联网 发布:少儿编程前景 编辑:程序博客网 时间:2024/06/01 07:52
一、web开发中的数据库操作
1、在web开发中,几乎都要涉及到数据库操作
2、web服务提供的数据,大部分是存储在数据库中的
3、数据的crud(create read update delete)操作,都需要数据库的支持
4、业界为数据存储专门提供了单独的数据库产品,满足各种数据存储的需求
二、现在数据库包括
1、关系型数据库,通常用sql语句进行数据操作 常见的有: mysql,oracle,postgresql(开源)
2、nosql(非关系型数据库) HBase, Cassandra,MongoDB,Redis
3、关系型数据库,目前最为常用的是开源数据库mysql,postgresql
4、服程序使用相应的客户端连接库访问DB server
5、本课程使用另一种更简单的数据库(sqlite),没有数据库服务,数据操作被做成库,python内置了sqlite的操作库
6、Django ORM (object relational mapping)技术,简化了数据库开发的逻辑,提供了开发的效率,屏蔽了不同的数据库访问的底层细节,切换数据库时,不需要改动代码,只需要配置改改
三、Django的数据库设置
1、在 settings.py中定义
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), }}
ENGINE是说明使用的数据库的索引
NAME是具体数据库的名字,可以改
2、定义数据库表的文件
数据库表的定义,一般是放在应用的models.py中的
还需要在配置文件ci/settings.py中,加入我们的应用
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'dandan']
migrate命令: python manage.py migrate
由于django提供了ORM这种数据库的操作方式,都是通过高层的面向对象的开发,屏蔽了底层数据库操作的细节,不需要定义sql语句,只需要在应用的models.py下面定义一个类就行了
为什么要定义在models.py下面
MVC模式,model-view-controller 模型 视图 控制器
三者的分工:model是用于封装与应用程序的业务逻辑相关的数据以及对数据的处理方法,封装和处理数据用的
view 展示数据用的
controller 控制业务逻辑用的
# 课程class Course(models.Model): #课程名 name = models.CharField(max_length=100) #课程描述 desc = models.CharField(max_length=2000, null=True, blank=True) #展示优先级 display_idx = models.PositiveSmallIntegerField(default=0) class Meta: db_table = "dan_course" dan前缀的作用把name字段定义成类的静态属性,是个CharField字符串,positiveSmallTnterger,最小正整数,positive是正数的意思,其他的表
的字段类型可以查找django的文档 https://docs.djangoproject.com,最好看中文文档
可以为空要填null = true,空格blank= True表示空格也是对的,空字符串和空不同,空字符串也有数据
default是课程描述的意思,
Meta定义的类的其他信息
django中很少创建表,都是通过orm系统去做
只在models.py中定义这个表还不行,得在setting.py中的INSTALLED_APPS中加进去
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'dan']接下来去创建这张表
产生相应的数据操作脚本
python manage.py makemigrations dan
执行数据操作脚本
python manage.py migrate
如果修改model,再次执行 ,两个命令都要执行
主流数据库的配置
DATABASES = { 'default':{ 'ENGINE':'django.db.backends.mysql', 'NAME':'', 'USER':'XXX', 'PASSWORD':'XXX', 'HOST':'', 'PORT':'', 'CONN_MAX_AGE':0, 'OPTIONS':{ "init_command":"SET storage_engine=INNODB" } }}
- web开发第四课数据库操作
- 第四章 数据库操作
- Flask Web 开发 数据库操作 Sqlalchemy
- 【Web探索之旅】第二部分第四课:数据库
- Web探索之旅 | 第二部分第四课:数据库
- 《应用Rails进行敏捷Web开发》第四版部分翻译--Rails和数据库
- Web Service 第四课
- Web第四节课
- Web Service开发总结一 对数据库的操作
- 模拟web开发环境 对MySql数据库的操作
- web开发 mysql数据库操作 之 分页技术
- java web数据库操作
- Java web 数据库 操作
- 数据库学习第四课
- 数据库第四课
- C#第四次作业 数据库操作
- 《flask web开发》第四章重点
- Flask Web 开发 数据库
- Wannafly模拟赛 树(dp)
- 9.4 9.5 学到了什么
- Swift
- 基于jQuery的zTree树插件实现筛选
- iptables规则的查看、添加、删除和修改
- web开发第四课数据库操作
- C#编写的计算器程序(仿windows自带的计算器)
- AndroidUtils(六)SP工具类
- 371. Sum of Two Integers, 不用加减乘除运算符计算两数之和
- 在SpringBoot中使用 拦截器
- 字典的数据采集模块
- 阿里四面面经
- springmvc整合freemarker
- Quartz延时任务实现