10.31編程總結

1.django手動創建數據庫

DROP TABLE IF EXISTS `wish_account`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `wish_account` (
  `idwish_account` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(100) DEFAULT NULL,
  `client_id` varchar(200) DEFAULT NULL,
  `client_secret` varchar(200) DEFAULT NULL,
  `access_token` varchar(200) DEFAULT NULL,
  `refresh_token` varchar(200) DEFAULT NULL,
  `merchant_user_id` varchar(2000) DEFAULT NULL,
  PRIMARY KEY (`idwish_account`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;

--
-- Dumping data for table `wish_account`
--

LOCK TABLES `wish_account` WRITE;
/*!40000 ALTER TABLE `wish_account` DISABLE KEYS */;
INSERT INTO `wish_account` VALUES (1,'Wish','5742b508d75bc459376b7fd0','d76f895e09314be6832f4310750d08f7','b4c9ee9633c84ec59ab8c6f8afe78808','3c84745a2c264ec8b999d540e4c97128','5567d485d8a40b19e85363e4');
/*!40000 ALTER TABLE `wish_account` ENABLE KEYS */;
UNLOCK TABLES;

2.django常用的基本命令*重點重點啊

Django 基本命令

本節主要是爲了讓您瞭解一些django最基本的命令,請嘗試着記住它們,並且多多練習下,特別是標記爲紅色的那些
1. 新建一個 django project
django-admin.py startproject project-name

一個 project 爲一個項目,project-name 項目名稱,改成你自己的,要符合Python 的變量命名規則(以下劃線或字母開頭)
2. 新建 app
python manage.py startapp app-name
或 django-admin.py startapp app-name

一般一個項目有多個app, 當然通用的app也可以在多個項目中使用。
3. 同步數據庫
python manage.py syncdb

注意:Django 1.7.1及以上的版本需要用以下命令
python manage.py makemigrations
python manage.py migrate

這種方法可以創建表,當你在models.py中新增了類時,運行它就可以自動在數據庫中創建表了,不用手動創建。

備註:對已有的 models 進行修改,Django 1.7之前的版本的Django都是無法自動更改表結構的,不過有第三方工具 south,詳見 Django 數據庫遷移 一節。
4. 使用開發服務器

開發服務器,即開發時使用,一般修改代碼後會自動重啓,方便調試和開發,但是由於性能問題,建議只用來測試,不要用在生產環境。
python manage.py runserver

# 當提示端口被佔用的時候,可以用其它端口:
python manage.py runserver 8001
python manage.py runserver 9999
(當然也可以kill掉佔用端口的進程)

# 監聽所有可用 ip (電腦可能有一個或多個內網ip,一個或多個外網ip,即有多個ip地址)
python manage.py runserver 0.0.0.0:8000
# 如果是外網或者局域網電腦上可以用其它電腦查看開發服務器
# 訪問對應的 ip加端口,比如 http://172.16.20.2:8000
5. 清空數據庫
python manage.py flush

此命令會詢問是 yes 還是 no, 選擇 yes 會把數據全部清空掉,只留下空表。
6. 創建超級管理員
python manage.py createsuperuser

# 按照提示輸入用戶名和對應的密碼就好了郵箱可以留空,用戶名和密碼必填

# 修改 用戶密碼可以用:
python manage.py changepassword username
7. 導出數據 導入數據
python manage.py dumpdata appname > appname.json
python manage.py loaddata appname.json

關於數據操作 詳見:數據導入數據遷移,現在瞭解有這個用法就可以了。
8. Django 項目環境終端
python manage.py shell

如果你安裝了 bpython 或 ipython 會自動用它們的界面,推薦安裝 bpython。

這個命令和 直接運行 python 或 bpython 進入 shell 的區別是:你可以在這個 shell 裏面調用當前項目的 models.py 中的 API,對於操作數據,還有一些小測試非常方便。
9. 數據庫命令行
python manage.py dbshell

Django 會自動進入在settings.py中設置的數據庫,如果是 MySQL 或 postgreSQL,會要求輸入數據庫用戶密碼。

在這個終端可以執行數據庫的SQL語句。如果您對SQL比較熟悉,可能喜歡這種方式。
10. 更多命令
終端上輸入 python manage.py 可以看到詳細的列表,在忘記子名稱的時候特別有用。

3.退出shell命令的總結

用途說明

exit命令用於退出當前shell,在shell腳本中可以終止當前腳本執行。


常用參數

格式:exit n

退出。設置退出碼爲n。(Cause the shell to exit with a status of n.)



格式:exit

退出。退出碼不變,即爲最後一個命令的退出碼。(If n is omitted, the exit status is that of the  last  command executed. )



格式:$?

上一個命令的退出碼。



格式:trap "commands" EXIT

退出時執行commands指定的命令。( A trap on EXIT is executed before the shell terminates.)



退出碼(exit status,或exit code)的約定:

0表示成功(Zero - Success)

非0表示失敗(Non-Zero  - Failure)

2表示用法不當(Incorrect Usage)

127表示命令沒有找到(Command Not Found)

126表示不是可執行的(Not an executable)

>=128 信號產生

4.MySQL更新中文列:1366Incorrectstringvalue問題解決

解決:

1、數據庫schema字符集設置爲utf-8

2、表字符集設置爲utf-8

3、中文列字符集設置爲utf-8

4、連接url裏面已經指定了CharsetEncode=utf8

第4步非常關鍵。

備註:

1、看數據庫字符集

show create database test;

2、看數據表字符集
show create table t_data;

3.某個字段報錯就改字符編碼

 alter table users modify username char(20) character set utf-8; 

5.ajax模板

$.ajax({
          url: "/yapush/wish/get_wish_count/",
          type: "POST",
          datatype: "json",
          data: {"csrfmiddlewaretoken": csrf_token},
          success: function (result) {
              var result = JSON.parse(result)
              console.log(result)
              $.each(result, function (index, value) {
                  $("#wish_stores_id").append("<li><a  onclick='changeStore(this)' href='javascript:void(0);' >"+value+"</a></li>");
              })
          }, error: function (emsg) {
              console.log(emsg);
          }
      })
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章