2016 - 3 - 12 SQLite的學習之SQL語言入門

来源:http://www.cnblogs.com/BJTUzhengli/archive/2016/03/12/5268841.html
-Advertisement-
Play Games

1.SQL語句的特點: 1.1 不區分大小寫 1.2 每條語句以;結尾 2.SQL語句中常用關鍵字: select,insert,update,from,create,where,desc,order,by,group,table,alter,view,index等。 資料庫中不能出現與上述關鍵字重


 

   1.SQL語句的特點:

    1.1 不區分大小寫 

    1.2 每條語句以;結尾

 

  2.SQL語句中常用關鍵字:

    select,insert,update,from,create,where,desc,order,by,group,table,alter,view,index等。

    資料庫中不能出現與上述關鍵字重名的表名和欄位。

 

  3.SQL語言種類:

   3.1

     數據定義語句: Data Defination Language; (DDL) 

     包括create和drop等操作

     包括創建表或者刪除表(create table 和 drop table)

   3.2

      數據操作語言: Data Manipulation Language (DML)

      包括insert,update,delete等操作

      上述三種操作分別作用於添加,修改,刪除表中數據

   3.3

       數據查詢語言:Data Query Language (DQL)

       關鍵字select是DQL中用的最多的操作

       其他常用的DQL中的關鍵字如 where,order by, group by 和 having.

 

  4.SQL語句使用舉例

    4.1 DDL (數據定義語言)

     4.1.1 創建表格 

      creat table 表名(欄位名1 欄位類型1,欄位名2 欄位類型2)

      例如 : CREATE table t_student(id integer PRIMARY key, name text);

      實際上SQLite是無類型的,就是是申明為integer類型,一樣可以存儲字元串數據(主鍵除外)

     4.1.2 刪除表格

      drop table 表名

      例如:DROP TABLE t_student; 

     

    4.2DML(數據操作語言)

 

      4.2.1 插入數據

        insert to 表名 (欄位1,欄位2)values(欄位1的值,欄位2的值)

        例如:INSERT into t_student(id,name)VALUES(1,'zhengli');

      4.2.2 修改數據

         update 表名 set 欄位1 = 欄位1 新值

        例如: update t_student set name = 'zhengli';(註意這樣寫會將表中的所有name的值更改)

      4.2.3 刪除數據

         delete from 表名

         例如: delete from t_student ; (與上面的語句一樣,會刪除表中所有數據!但不會刪除表);

     在上面的所有語句中,都可以加上條件語句,例如: update t_student set name = 'tangyi'where id = 1;        

     這樣就只會修改 id =1 的數據。同時可以用and表示C語言中的&& or表示||。

 

 

   4.3 DQL語句 (數據查詢語句)

 

    4.3.1 按照條件查詢

    select 欄位1,欄位2,... from 表名

    select *from 表名  (查詢表中所有欄位)

 

    4.3.2  排序查詢

     select * from 表名 oder by 欄位名(預設升序)

     select * from 表名 order by 欄位名 desc (降序)

 

   4.3.3  limit

     select *from 表名 order by 欄位名 (升序) limit 數值1,數值2

     表示從表中取數據並按升序排列,跳過前數值1個數據,取數值2個數據

     如: select * from t_student order by id limit 0,5;

     升序排序取出前五條數據。

            select *from t_student order by age desc limit 2,3;

     降序排序 跳過前2條數據 取之後的3條數據

 

     4.3.4 約束

     內鍵約束

      建表時可以給特定的欄位設置一些約束條件,常見的約束有

      1.not null 該欄位不能為空

      2.unique 該欄位的值唯一,不能重覆

      3. default 制定該欄位的預設值

      例如:  create table t_student (id integer primary key , name text not null unique,age integer not null default 1)

     表名該表中的 name欄位不能為空且不能重覆,age不能為空且預設為1;

  

     外鍵約束

     利用外鍵約束,可以建立表與表之間的聯繫

     外鍵約束的一般情況是,一張表的某個欄位,引用著另一張表的主鍵欄位

     例如: 

     create table t_student(id integer primary key ,name text,class_id integer constraint fk_t_student_class_id_t_class_id foreign key (class_id) references t_class(id));

  

  

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • MySQL 目前的最新版本是 5.7.11,在 Linux 下提供特定發行版安裝包(如 .rpm)以及二進位通用版安裝包(.tar.gz)。一般情況下,很多項目都傾向於採用二進位通用安裝包形式來進行安裝配置,自定義非常方便。但在安裝過程中發現,其實官方提供的安裝說明文件太過簡單,而且裡面的參數還有問
  • Buffer cache hit ratio官方是這麼解釋的:“指示在緩衝區高速緩存中找到而不需要從磁碟中讀取的頁的百分比。”   Buffer cache hit ratio被很多人當做判斷記憶體的性能指標之一(我沒說僅僅只看這個計數器的值,實際上我現在都不看這個值了), 也有不少給給出了具體的參數
  • 我們究竟應該如何對MySQL資料庫進行優化?下麵我就從MySQL對硬體的選擇、MySQL的安裝、my.cnf的優化、MySQL如何進行架構設計及數據切分等方面來說明這個問題。 伺服器物理硬體的優化 在挑選硬體伺服器時,我們應該從下麵幾個方面著重對MySQL伺服器的硬體配置進行優化,也就是說將項目...
  • //mysql_select//gcc mysql_select.c -o test -I /usr/include/mysql -L /usr/lib -lmysqlclient #include <stdio.h>#include <string.h>#include <mysql/mysql.
  • 如何看待科技、數據和業務的關係?自己的一些理解。
  • 在實現分庫分表的情況下,資料庫自增主鍵已無法保證自增主鍵的全局唯一。為此,MyCat 提供了全局sequence,並且提供了包含本地配置和資料庫配置等多種實現方式。 本地文件方式 原理:此方式MyCAT將sequence配置到文件中,當使用到sequence中的配置後,MyCAT會更下conf中的s
  • 操作系統:Centos 7.1 mysql資料庫版本:mysql5.7.9 mysql官方網站:http://www.mysql.com 1、安裝新版mysql之前,我們需要將系統自帶的mariadb-lib卸載 2、到mysql的官網下載最新版mysql的rpm集合包:mysql-5.7.9-
  • 微軟提供了一個很好用的工具performance dashboard: 下載地址: http://www.microsoft.com/en-us/download/details.aspx?id=29063 步驟: 1. 下載 2. 安裝 3. 到目錄 C:\Program Files (x86)\
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...