資料庫mysql的基本命令

来源:http://www.cnblogs.com/scnuyz/archive/2016/08/16/5778104.html
-Advertisement-
Play Games

問題分析 當數據量很大的時候,所有數據都集中在一個文本文件中的話,讀寫會很困難,記憶體消耗大,速度很慢 操作很麻煩,因為讀寫都要根據指定的格式盡心解析,不通用 每次獲取數據都要全部數據重新讀寫,不能通過對索引對指定的數據進行讀寫 數據衝突的解決方案要完全依賴Java app去實現 更多的功能,像排序, ...


問題分析

  • 當數據量很大的時候,所有數據都集中在一個文本文件中的話,讀寫會很困難,記憶體消耗大,速度很慢
  • 操作很麻煩,因為讀寫都要根據指定的格式盡心解析,不通用
  • 每次獲取數據都要全部數據重新讀寫,不能通過對索引對指定的數據進行讀寫
  • 數據衝突的解決方案要完全依賴Java app去實現
  • 更多的功能,像排序,也要完全通過Java app實現

 

知識點

1. 資料庫中的關鍵結構組織和屬性

 ——是存儲數據的最基本單元 
表裡麵包含有欄位和數據

欄位: 
欄位名,欄位類型,主鍵,是否允許為空,預設值 
欄位類型就是欄位的數據類型 
比較常用的有 字元串varchar/text 整型int 浮點型double 日期datetime/date

這裡簡單說一下date和datetime區別 
DATETIME類型可用於需要同時包含日期和時間信息的值。 
MySQL 以 ‘YYYY-MM-DD HH:MM:SS’格式檢索與顯示 DATETIME 類型。支持的範圍是’1000-01-01 00:00:00’ 到 ‘9999-12-31 23:59:59’。(“支持”的含義是,儘管更早的值可能工作,但不能保證他們均可以。) 
DATE類型可用於需要一個日期值而不需要時間部分時。MySQL 以 ‘YYYY-MM-DD’ 格式檢索與顯示DATE值。支持的範圍是 ‘1000-01-01’ 到’9999-12-31’。

主鍵:一條數據的主索引,設為主鍵的欄位,數據不能重覆,一個表中只有一個主鍵,可用於表示當前這條數據

是否允許為空 
欄位屬性,表示插入一條數據的時候,是否允許不插入該欄位對應的數據(即為null),主鍵不能為空 
預設值 
欄位屬性,可不設置,表示插入一條數據的時候,如果不插入某欄位對應的數據,系統會自動插入其預設值

2. MySQL基本命令 
註意每一句都要以分號結束

查看有哪些資料庫 
show databases ;

進入某個庫
use 庫名; 

查看當前庫中有哪些表
show tables ;

查看該表具體結構
desc 表名 ; 

新建庫,庫名為test
create database test ;

刪除庫
drop database if exists test ; 

新建表 
create table account1{
    code varchar(6) not null,
    password int(6) not null,
    money double(5,2) not null,
    primary key(code)
    }

刪除表
drop table if exists account1 ;

插入全部欄位數據
insert into 表名 value(欄位1值, 欄位2值, 欄位3值);
insert into account1 value('100001',111111,100.00);
insert into account1 value('100002',222222,200.00);
insert into account1 value('100003',333333,300.00);
註意:字元串用英文單引號引住

插入部分欄位數據:
insert into 表名(欄位1, 欄位2) value(欄位1值, 欄位2值);
insert into account1(code,password) value('10004',444444);

允許為空(表account2)
create table account2(
    code varchar(6) ,
    password int(6) ,
    money double(5,2),
    primary key(code)
);

設預設值(表account3)
create table account3(
    code varchar(6) not null,
    password int(6) not null,
    money double(5,2) not null default 0.0,
    primary key(code)
);

自增(表account4)
如果一個主鍵是數字類型,可以設置為自增欄位,那麼插入數據時,不用插入主鍵,主鍵會從1開始遞增
create table account4 (
    code int (6) not null auto_increment,
    password int(6) not null,
    money double(5,2) not null, 
    primary key (code)
);


查詢數據 整表查詢:
select * from 表名;(*表示所有欄位)

個別欄位查詢:
select 欄位1,欄位2 from 表名;

條件查詢:where後面帶出條件語句
select * from account1 where code='100002';
select password from account1 where code='100002';
select * from account1 where code='100002' and password=111111; (and表示“且”)
select * from account1 where code='100002' or password=111111; (or表示“或”)
select * from account1 where money>200.00;

修改數據 
update 表名 set 欄位1=值1,欄位2=值2;(一般要加條件)
update account1 set password=123;(不加條件,整個表的數據被修改)
update account1 set password=123 where code='100002'; (只修改該條件對應的數據)
update account1 set password=123,money=0 where code='100002'; (同時修改多個欄位)


刪除數據
delete from 表名;(一般要加條件)
delete from account1;(不加條件,整個表的數據被刪除)
delete from account1 where code='100006'; (只刪除該條件對應的數據)

3、varchar(6)、int(6)、double(5,2)括弧中的數字分別代表什麼意思?

varchar(6):插入的字元串欄位不能超過6個字元

int(6):這裡的6並不是只能插入6位以內的數字,對於普通的int欄位來說,int(6)與int(11)沒有區別,插入的數字只要不超過int的範圍(4位元組)即可;對於設置為補零(zerofill)的int欄位,int(6)表示當數位不足6位時,前面就補零至6位,如插入333,系統會補零為000333(補零的情況比較少用,暫不詳述)

double(5,2):保留2位小數後,整個長度(含小數)不能超過5位(如:123.123在範圍內,可以插入;1231.23在範圍外,不能插入)

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

-Advertisement-
Play Games
更多相關文章
  • jquery easyui使用······(一) ...
  • 新人剛學習Android兩周,寫一個隨筆算是對兩周學習成果的鞏固,不足之處歡迎各位建議和完善。 這次寫的是一個簡單登錄案例,大概功能如下: 註冊的賬戶信息用SharedPreferences存儲; 登錄成功後跳轉到成功頁面,在成功頁面聯網請求圖片並寫入到外部存儲; 然後讀出顯示在成功頁面; 註冊xm ...
  • Swift - EasingAnimation繪製圓環動畫 效果 源碼 https://github.com/YouXianMing/Swift-Animations ...
  • 一個懶人如何做到有條理、有效率的學習? 作為一個懶人,對於費事費力的學習我是拒絕的,那麼我就該考慮,怎麼才能做到高效快速的學習呢?於是在不斷總結中找到自己的學習方法,在這裡發出來給大家借鑒一下,取其精華去其糟粕,不喜勿噴哦。 我的學習方法就是帶著問題去學習理解,然後實戰應用並做好筆記。這四點缺一不可 ...
  • 要點: 1、多種形態,引用的多種形態對於一個引用變數,可以指向任何類的對象。對於一個父類的引用(類與類之間有一種繼承關係),可以指向子類,也可以指向本類,指向的類型不同。當通過此引用向對象發送消息,調用的方法是不同的,此時方法的調用就是多態。 2、類與類之間有關係,繼承關係父類的引用可以指向子類的引 ...
  • 工作筆記記錄,會持續更新.... 目錄: apply tapply lapply sapply merge apply函數: apply:apply的中文意思是應用,這個函數的意思是通過將一個函數應用到矩陣或數組中,返回一個向量或數組 語法:apply(X, MARGIN, FUN, ...) , ...
  • 在我的實際工作中,數據來源一方面是關係型資料庫MS SqlServer, 別一方面是HBase。本節主要介紹通過RODBC訪問MS SqlServer 安裝配置,參見資料(https://msdn.microsoft.com/en-us/library/hh568454(v=sql.110).asp ...
  • 前幾章對R語言的運行原理、基本語法、數據類型、環境部署等基礎知識作了簡單介紹,本節將結合具體案例進行驗證測試。 案例場景:從互聯網下載全國三甲醫院數據,以地圖作為背景,展現各醫院在地圖上的分佈圖。全國三甲醫院數據來源 http://www.wxmp.cn/cms/detail-51610-23480 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...