問題分析 當數據量很大的時候,所有數據都集中在一個文本文件中的話,讀寫會很困難,記憶體消耗大,速度很慢 操作很麻煩,因為讀寫都要根據指定的格式盡心解析,不通用 每次獲取數據都要全部數據重新讀寫,不能通過對索引對指定的數據進行讀寫 數據衝突的解決方案要完全依賴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在範圍外,不能插入)