11.22 django和數據庫、html頁面之間的操做

靜態文件配置:

  • 默認狀況下全部html文件都是放在templates文件夾內css

  • 什麼是靜態文件:網站所使用到的提早寫的CSS、js、 第三方的前端模塊 圖片 都叫靜態資源html

  • 默認狀況下網站所用到的靜態文件資源所有會放在static文件夾下前端

    • 一般狀況下 在static文件夾內部還會再建其餘文件夾
      • CSS 文件夾
      • js 文件夾
      • font 文件夾
      • img 文件夾
      • Bootstrap
      • fontawesome
    • django中 須要本身手動建立靜態文件存放的文件夾
  • STATIC_URL = '/static/' #訪問靜態文件資源接口前綴 一般狀況下接口前綴的名字也叫staticpython

  • 手動開設靜態文件訪問資源mysql

    STATIC_URL = '/static/'  # 訪問靜態文件資源接口前綴  一般狀況下接口前綴的名字也叫static
    		# 手動開設靜態文件訪問資源
    		STATICFILES_DIRS = [  # 靜態資源所在的文件夾路徑
    			os.path.join(BASE_DIR,'static'),  # 將static文件裏面全部的資源暴露給用戶
    			os.path.join(BASE_DIR,'static1'),  # 將static文件裏面全部的資源暴露給用戶
    			# os.path.join(BASE_DIR,'static2'),  # 將static文件裏面全部的資源暴露給用戶
    		]
  • 靜態文件動態綁定(****)sql

{% load static %}
		<link rel="stylesheet" href="{% static 'bootstrap-3.3.7-dist/css/bootstrap.min.css' %}">
		<script src="{% static 'bootstrap-3.3.7-dist/js/bootstrap.min.js' %}"></script>
  • form表單默認朝後端發的是get請求數據庫

    • get請求也可以攜帶參數
    http://127.0.0.1:8000/login/?username=jason&password=jason123
    特色:url?xxx=xxx&yyy=yyy

    1.攜帶的數據不安全django

    2.攜帶的數據大小有限制bootstrap

    3.一般只會攜帶一些不是很重要的數據後端

  • action

​ 1.不寫 默認朝當前地址提交

​ 2.只寫後綴/index

​ 3.寫全路徑

  • 前期咱們在朝後端提交post請求出現403的狀況,須要去配置文件中註釋掉一行
# 中間件
MIDDLEWARE = [
                'django.middleware.security.SecurityMiddleware',
                'django.contrib.sessions.middleware.SessionMiddleware',
                'django.middleware.common.CommonMiddleware',
                 #'django.middleware.csrf.CsrfViewMiddleware',
                'django.contrib.auth.middleware.AuthenticationMiddleware',
                'django.contrib.messages.middleware.MessageMiddleware',
                'django.middleware.clickjacking.XFrameOptionsMiddleware',
		]
  • django後端的視圖函數 默認處理的是get請求

​ 不管是發get請求仍是post請求 都會執行視圖函數

def login(request):
	print('來啦 老弟~')
	return render(request,'login.html')

get請求只想拿到login頁面

post請求想提交數據 而後後端作校驗

  • 如何判斷當前請求方式
request.method 拿到的是字符串大寫的請求方式  GET POST

def login(request):
	# if request.method == 'GET':
	#     print('來啦 老弟~')
	#     print(request.method,type(request.method))  # 獲取前端請求方式
	#     return render(request,'login.html')
	# elif request.method == 'POST':
	#     print('post業務邏輯')
	#     return HttpResponse('收到了')
	if request.method == "POST":
		  return HttpResponse('收到了')
	return render(request,'login.html')

request方法初始

request.method  獲取請求方式  而且純大寫的字符串

request.POST    獲取用戶提交的post請求數據
		如何獲取用戶數據(******)
request.POST.get()  # 默認只會獲取列表最後一個元素
request.POST.getlist()  # 若是你想獲取列表 用getlist()

request.GET     獲取用戶提交的get請求數據
如何獲取用戶數據(******)
	request.GET.get()  # 默認只會獲取列表最後一個元素
	request.GET.getlist()  # 若是你想獲取列表 用getlist()

pycharm 鏈接數據庫

django鏈接MySQL

必需要有兩部操做
		1.配置文件配置
			DATABASES = {
					'default': {
						'ENGINE': 'django.db.backends.mysql',  # 指定數據庫類型
						'NAME': 'day49',  # 指定庫的名字
						'USER':'root',  # 注意 鍵必須是全大寫
						'PASSWORD':'123qwe',
						'HOST':'127.0.0.1',
						'PORT':3306,
						'CHARSET':'utf8'
					}
				}
		2.主動告訴django 不要用默認的mysqldb鏈接 而是用pymysql
			你能夠在項目名下的__init__.py中書寫
			也能夠在應用名下的__init__.py中書寫
			import pymysql
			pymysql.install_as_MySQLdb()
  • django orm簡介

    • orm 對象關係映射
    • 類 表
    • 對象 數據
    • 對象.屬性 字段對應的值
  • 爲何使用orm

    • 可以讓不會數據庫操做的人也可以簡單方便的去操做數據庫
  • orm的缺點

    • 封裝程度過高 有時候會出現查詢效率偏低的問題
    • 因此工做中 ,簡單的用orm,複雜的 追速度 須要你手動書寫sql語句
  • django中如何操做orm

    • 書寫模型類

    • 去應用下的model.py中書寫模型類

      以後在寫django項目的時候 一個django就對應一個數據庫

不要出現多個項目使用同一個數據的狀況

數據庫遷移(同步)命令

1.python3 manage.py makemigrations  # 將數據庫的修改 記錄到小本本上(migrations文件內)

	2.python3 manage.py migrate         # 將修改操做真正的同步到數據庫中

	上面兩條命令必須是成雙成對出現
	只要修改了models裏面跟數據庫相關的代碼  你就必須從新執行上面兩條命令
	***************************

模型表字段的增刪改查

  • 字段的修改
    • 直接修改代碼 而後執行數據庫遷移命令便可(兩條缺一不可)
  • 字段的添加
# 方式1  設置默認值
email = models.EmailField(default='123@qq.com')  # varchar
# 方式2   容許字段爲空
phone = models.BigIntegerField(null=True)
# 直接在提示中給默認值
gender = models.CharField(max_length=32)
  • 字段的刪除
    • 直接註釋掉對應的字段 而後執行數據庫遷移命令便可

模型表數據的增刪改查

查
		data = models.User.objects.filter(username=username)  # <QuerySet [<User: User object>]>
		"""
		filter返回的結果是一個"列表",裏面纔是真正數據對象
		filer括號內能夠放多個關鍵字參數 這多個關鍵字參數在查詢的時候 是and關係
		"""
		user_list = models.User.objects.all()  # models.User.objects.filter()
		"""
		結果是一個"列表" 裏面是一個個的數據對象
		"""
	增
		user_obj = models.User.objects.create(username=username,password=password)
        print(user_obj,user_obj.username,user_obj.password)
		# create方法會有一個返回值  返回值就是當前被建立的對象自己

	改
		models.User.objects.filter(id=edit_id).update(username=username,password=password)
        """
        批量操做  會將filter查詢出來的列表中全部的對象所有更新
        """

	刪(通常狀況下不會使用)
		models.User.objects.filter(id=delete_id).delete()
		"""
			批量操做  會將filter查詢出來的列表中全部的對象所有刪除
		"""
相關文章
相關標籤/搜索