django 连接数据库 sqlite的例子


Posted in Python onAugust 14, 2019

Aphorism

the fight is worth it.

django models 连接 sqlite 数据库

django 版本为 1.11.7

在 blog 项目下创建一个 app article :python manage.py startapp article

在 blog 项目结构下会多出一个 article 目录

在 article 下面的 models.py 文件中输入

from django.db import models
  class Article(models.Model):
   name = models.CharField('名称',max_length = 30)
   age = models.CharFiels('年龄',max_length = 5)
   class Meta:
    db_table = 'Article'

step4: 在 子blog 目录中 修改 setting.py 文件

- 要连接到哪种数据库 : sqlite ? mysql?
- 连接的数据库路径

下面这种配置表示:

1. sqlite 数据库 和 在项目根目录下 创建一个 article.db 数据库文件

2. 数据库的类型 以及 数据库的存储位置

DATABASES = {
  'default': {
   'ENGINE': 'django.db.backends.sqlite3',
   'NAME': os.path.join(BASE_DIR, 'article.db'),
  }
 }

step5: 执行 python manage.py makemigrations

改动了 model.py的内容之后执行下面的命令:python manger.py makemigrations相当于 在该app下建立 migrations目录,并记录下你所有的关于modes.py的改动,比如0001_initial.py, 但是这个改动还没有作用到数据库文件

cmd 中会显示

Migrations for 'article':
 article\migrations\0001_initial.py
 - Create model Article

step6: 执行 python manage.py migrate

在第5步之后执行命令 将该models.py改动 作用到数据库文件,说明 /blog/article数据库文件已经被改变了,生成表格或者操作了数据

cmd 中 显示:

(blog) C:\Users\by\Desktop\review\python\blog\blog>python manage.py migrate
Operations to perform:
 Apply all migrations: admin, article, articles, auth, contenttypes, sessions
Running migrations:
 Applying contenttypes.0001_initial... OK
 Applying auth.0001_initial... OK
 Applying admin.0001_initial... OK
 Applying admin.0002_logentry_remove_auto_add... OK
 Applying article.0001_initial... OK
 Applying articles.0001_initial... OK
 Applying contenttypes.0002_remove_content_type_name... OK
 Applying auth.0002_alter_permission_name_max_length... OK
 Applying auth.0003_alter_user_email_max_length... OK
 Applying auth.0004_alter_user_username_opts... OK
 Applying auth.0005_alter_user_last_login_null... OK
 Applying auth.0006_require_contenttypes_0002... OK
 Applying auth.0007_alter_validators_add_error_messages... OK
 Applying auth.0008_alter_user_username_max_length... OK
 Applying sessions.0001_initial... OK

step7: 执行 python manage.py sqlmigrate app_name 0001

这个命令用于查看 生成的 sql语句, 这个命令相当于之前 django 版本中的 sqlall

cmd 中显示:

(blog) C:\Users\by\Desktop\review\python\blog\blog>python manage.py sqlmigrate article 0001
BEGIN;
--
-- Create model Article
--
CREATE TABLE "Article" ("id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, "name" varchar(30) NOT NULL, "age" varchar(5) NOT NULL);
COMMIT;

step8: 执行命令 python manage.py dbshell

可以看看数据中是否生成了对应的表,显然本例子中 Article 生成,Articles 是我之前启动的另一个 app

或者 sqlite3 article.db 然后 .tables也可以查看

cmd 中

(blog) C:\Users\by\Desktop\review\python\blog\blog>python manage.py dbshell
SQLite version 3.7.15.2 2013-01-09 11:53:05
Enter ".help" for instructions
Enter SQL statements terminated with a ";"
sqlite> .tables
Article      auth_user_groups
Articles     auth_user_user_permissions
auth_group     django_admin_log
auth_group_permissions  django_content_type
auth_permission    django_migrations
auth_user

使用 python shell insert 数据到 article.db 中

execute python manage.py shell 进入项目的 python 命令执行环境中

使用python 语法往数据库 insert 数据

>>> from article.models import Article

## 等价写法: from articles import models.Article 


>>> Article.objects.create(name='tom',age='12')
<Article: Article object>
>>> Article.objects.create(name='juice',age='13')
<Article: Article object>

查看article.db 数据库:

sqlite article.db
select * from article
sqlite> select * from Article
 ...> ;
1|tom|12
2|juice|13
sqlite>

以上这篇django 连接数据库 sqlite的例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python回调函数用法实例详解
Jul 02 Python
Python实现发送与接收邮件的方法详解
Mar 28 Python
Python列表list排列组合操作示例
Dec 18 Python
python中的数据结构比较
May 13 Python
django的model操作汇整详解
Jul 26 Python
详解基于python-django框架的支付宝支付案例
Sep 23 Python
在vscode中配置python环境过程解析
Sep 28 Python
python实现输入的数据在地图上生成热力图效果
Dec 06 Python
Python面向对象程序设计之私有变量,私有方法原理与用法分析
Mar 23 Python
Python使用多进程运行含有任意个参数的函数
May 02 Python
Python DES加密实现原理及实例解析
Jul 17 Python
M1芯片安装python3.9.1的实现
Feb 02 Python
Python将主机名转换为IP地址的方法
Aug 14 #Python
Python利用WMI实现ping命令的例子
Aug 14 #Python
使用Windows批处理和WMI设置Python的环境变量方法
Aug 14 #Python
python for循环remove同一个list过程解析
Aug 14 #Python
如何用Python来理一理红楼梦里的那些关系
Aug 14 #Python
django之自定义软删除Model的方法
Aug 14 #Python
python实现登录密码重置简易操作代码
Aug 14 #Python
You might like
如何给phpadmin一个保护
2006/10/09 PHP
php array_push()数组函数:将一个或多个单元压入数组的末尾(入栈)
2011/07/12 PHP
解析web文件操作常见安全漏洞(目录、文件名检测漏洞)
2013/06/29 PHP
curl实现站外采集的方法和技巧
2014/01/31 PHP
JavaScript 语言的递归编程
2010/05/18 Javascript
js操作时间(年-月-日 时-分-秒 星期几)
2010/06/20 Javascript
jquery下json数组的操作实现代码
2010/08/09 Javascript
chrome不支持form.submit的解决方案
2015/04/28 Javascript
Bootstrap每天必学之前端开发框架
2015/11/19 Javascript
js编写当天简单日历效果【实现代码】
2016/05/03 Javascript
AngularJS教程之MVC体系结构详解
2016/08/16 Javascript
Bootstrap警告框(Alert)插件使用方法
2017/03/21 Javascript
vue2.0中click点击当前li实现动态切换class
2017/06/21 Javascript
浅析webpack 如何优雅的使用tree-shaking(摇树优化)
2017/08/16 Javascript
Node.js成为Web应用开发最佳选择的原因
2018/02/05 Javascript
JS简单实现查看文档创建日期、修改日期和文档大小的方法示例
2018/04/08 Javascript
解决bootstrap-select 动态加载数据不显示的问题
2018/08/10 Javascript
vue实现pdf导出解决生成canvas模糊等问题(推荐)
2018/10/18 Javascript
微信小程序实现蒙版弹窗效果
2018/11/01 Javascript
详解vue 不同环境配置不同的打包命令
2019/04/07 Javascript
javascript实现的图片预览和上传功能示例【兼容IE 9】
2020/05/01 Javascript
Python实现PS滤镜的万花筒效果示例
2018/01/23 Python
分享一下Python数据分析常用的8款工具
2018/04/29 Python
解决csv.writer写入文件有多余的空行问题
2018/07/06 Python
解决Python2.7中IDLE启动没有反应的问题
2018/11/30 Python
Django框架ORM数据库操作实例详解
2019/11/07 Python
python 多进程队列数据处理详解
2019/12/23 Python
pymysql之cur.fetchall() 和cur.fetchone()用法详解
2020/05/15 Python
Python控制台实现交互式环境执行
2020/06/09 Python
What is the purpose of Void class? Void类的作用是什么?
2016/10/31 面试题
中科方德软件测试面试题
2016/04/21 面试题
乡镇八一建军节活动方案
2014/08/24 职场文书
个人批评与自我批评总结
2014/10/17 职场文书
先进党支部申报材料
2014/12/24 职场文书
PyTorch梯度裁剪避免训练loss nan的操作
2021/05/24 Python
告别网页搜索!教你用python实现一款属于自己的翻译词典软件
2021/06/03 Python