下載Navicat Premium可以在網路搜索關鍵字,出來結果後建議選擇經過網路安全認證的,因為比較安全。
到這里介紹了Navicat兩種簡單的操作方式。當然這兩種方式對於大多數功能來說都夠用也非常常用。至於其它的功能相信你把這兩種功能熟練了之後也會用。常用的一些快捷鍵有:
1. ctrl + q: 打開新查詢窗口
2. ctrl + r: 運行當前窗口內的所有語句
3. ctrl + w: 關閉當前窗口
Ⅱ 為啥不能用uuid做MySQL的主鍵
在mysql中設計表的時候,mysql官方推薦不要使用uuid或者不連續不重復的雪花id(long形且唯一,單機遞增),而是推薦連續自增的主鍵id,官方的推薦是auto_increment,那麼為什麼不建議採用uuid,使用uuid究竟有什麼壞處?
一、mysql和程序實例 1.1.要說明這個問題,我們首先來建立三張表分別是user_auto_key,user_uuid,user_random_key,分別表示自動增長的主鍵,uuid作為主鍵,隨機key作為主鍵,其它我們完全保持不變.
根據控制變數法,我們只把每個表的主鍵使用不同的策略生成,而其他的欄位完全一樣,然後測試一下表的插入速度和查詢速度:
註:這里的隨機key其實是指用雪花演算法算出來的前後不連續不重復無規律的id:一串18位長度的long值
id自動生成表:
用戶uuid表
隨機主鍵表:
1.2.光有理論不行,直接上程序,使用spring的jdbcTemplate來實現增查測試: 技術框架:springboot+jdbcTemplate+junit+hutool,程序的原理就是連接自己的測試資料庫,然後在相同的環境下寫入同等數量的數據,來分析一下insert插入的時間來進行綜合其效率,為了做到最真實的效果,所有的數據採用隨機生成,比如名字、郵箱、地址都是隨機生成。
package com.wyq.mysqldemo;
import cn.hutool.core.collection.CollectionUtil;
import com.wyq.mysqldemo.databaseobject.UserKeyAuto;
import com.wyq.mysqldemo.databaseobject.UserKeyRandom;
import com.wyq.mysqldemo.databaseobject.UserKeyUUID;
import com.wyq.mysqldemo.diffkeytest.AutoKeyTableService;
import com.wyq.mysqldemo.diffkeytest.RandomKeyTableService;
import com.wyq.mysqldemo.diffkeytest.UUIDKeyTableService;
import com.wyq.mysqldemo.util.JdbcTemplateService;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.util.StopWatch;
import java.util.List;
@SpringBootTest
class MysqlDemoApplicationTests {
@Autowired
private JdbcTemplateService jdbcTemplateService;
@Autowired
private AutoKeyTableService autoKeyTableService;
@Autowired
private UUIDKeyTableService uuidKeyTableService;
@Autowired
private RandomKeyTableService randomKeyTableService;
@Test
void testDBTime() {
StopWatch stopwatch = new StopWatch("執行sql時間消耗");
/**
* auto_increment key任務
*/
final String insertSql = "INSERT INTO user_key_auto(user_id,user_name,sex,address,city,email,state) VALUES( , , , , , , )";
List<UserKeyAuto> insertData = autoKeyTableService.getInsertData();
stopwatch.start("自動生成key表任務開始");
long start1 = System.currentTimeMillis();
if (CollectionUtil.isNotEmpty(insertData)) {
boolean insertResult = jdbcTemplateService.insert(insertSql, insertData, false);
System.out.println(insertResult);
}
long end1 = System.currentTimeMillis();
System.out.println("auto key消耗的時間:" + (end1 - start1));
stopwatch.stop();
/**
* uudID的key
*/
final String insertSql2 = "INSERT INTO user_uuid(id,user_id,user_name,sex,address,city,email,state) VALUES( , , , , , , , )";
List<UserKeyUUID> insertData2 = uuidKeyTableService.getInsertData();
stopwatch.start("UUID的key表任務開始");
long begin = System.currentTimeMillis();
if (CollectionUtil.isNotEmpty(insertData)) {
boolean insertResult = jdbcTemplateService.insert(insertSql2, insertData2, true);
System.out.println(insertResult);
}
long over = System.currentTimeMillis();
System.out.println("UUID key消耗的時間:" + (over - begin));
stopwatch.stop();
/**
* 隨機的long值key
*/
final String insertSql3 = "INSERT INTO user_random_key(id,user_id,user_name,sex,address,city,email,state) VALUES( , , , , , , , )";
List<UserKeyRandom> insertData3 = randomKeyTableService.getInsertData();
stopwatch.start("隨機的long值key表任務開始");
Long start = System.currentTimeMillis();
if (CollectionUtil.isNotEmpty(insertData)) {
boolean insertResult = jdbcTemplateService.insert(insertSql3, insertData3, true);
System.out.println(insertResult);
}
Long end = System.currentTimeMillis();
System.out.println("隨機key任務消耗時間:" + (end - start));
stopwatch.stop();
String result = stopwatch.prettyPrint();
System.out.println(result);
}
user_key_auto寫入結果:
user_random_key寫入結果:
user_uuid表寫入結果
1.4.效率測試結果在已有數據量為130W的時候:我們再來測試一下插入10w數據,看看會有什麼結果:
可以看出在數據量100W左右的時候,uuid的插入效率墊底,並且在後序增加了130W的數據,uudi的時間又直線下降。
時間佔用量總體可以打出的效率排名為:auto_key>random_key>uuid,uuid的效率最低,在數據量較大的情況下,效率直線下滑。那麼為什麼會出現這樣的現象呢?帶著疑問,我們來探討一下這個問題:
二、使用uuid和自增id的索引結構對比 2.1.使用自增id的內部結構自增的主鍵的值是順序的,所以Innodb把每一條記錄都存儲在一條記錄的後面。當達到頁面的最大填充因子時候(innodb默認的最大填充因子是頁大小的15/16,會留出1/16的空間留作以後的 ? ? 修改):
①下一條記錄就會寫入新的頁中,一旦數據按照這種順序的方式載入,主鍵頁就會近乎於順序的記錄填滿,提升了頁面的最大填充率,不會有頁的浪費
②新插入的行一定會在原有的最大數據行下一行,mysql定位和定址很快,不會為計算新行的位置而做出額外的消耗
③減少了頁分裂和碎片的產生
2.2.使用uuid的索引內部結構因為uuid相對順序的自增id來說是毫無規律可言的,新行的值不一定要比之前的主鍵的值要大,所以innodb無法做到總是把新行插入到索引的最後,而是需要為新行尋找新的合適的位置從而來分配新的空間。
這個過程需要做很多額外的操作,數據的毫無順序會導致數據分布散亂,將會導致以下的問題:
①寫入的目標頁很可能已經刷新到磁碟上並且從緩存上移除,或者還沒有被載入到緩存中,innodb在插入之前不得不先找到並從磁碟讀取目標頁到內存中,這將導致大量的隨機IO
②因為寫入是亂序的,innodb不得不頻繁的做頁分裂操作,以便為新的行分配空間,頁分裂導致移動大量的數據,一次插入最少需要修改三個頁以上
③由於頻繁的頁分裂,頁會變得稀疏並被不規則的填充,最終會導致數據會有碎片
在把隨機值(uuid和雪花id)載入到聚簇索引(innodb默認的索引類型)以後,有時候會需要做一次OPTIMEIZE TABLE來重建表並優化頁的填充,這將又需要一定的時間消耗。
結論:使用innodb應該盡可能的按主鍵的自增順序插入,並且盡可能使用單調的增加的聚簇鍵的值來插入新行
2.3.使用自增id的缺點那麼使用自增的id就完全沒有壞處了嗎?並不是,自增id也會存在以下幾點問題:
①別人一旦爬取你的資料庫,就可以根據資料庫的自增id獲取到你的業務增長信息,很容易分析出你的經營情況
②對於高並發的負載,innodb在按主鍵進行插入的時候會造成明顯的鎖爭用,主鍵的上界會成為爭搶的熱點,因為所有的插入都發生在這里,並發插入會導致間隙鎖競爭
③Auto_Increment鎖機制會造成自增鎖的搶奪,有一定的性能損失
附:Auto_increment的鎖爭搶問題,如果要改善需要調優innodb_autoinc_lock_mode的配置
Ⅲ UUID的實現
提示一下,在oracle里是沒有uuid這個類型的數據的,至少我用的9i 和10g是沒有的,而是用varchar2(36)來替代的。所以可以在sql2000中也這樣用可變長度36位實現。
Ⅳ 如何在postgressql中創建uuid函數
有的。不過默認的安裝並未帶這些函數,是需要作為擴展SQL安裝上去的。函數名為uuid開頭的,類似uuid_generate_xxx。 另外,PostgreSQL從9.1開始安裝的方式有些不同,這些需要再搜索。 我用的PostgreSQL 9.3, 使用命令create extension "uuid-oos...
Ⅳ SQL 一張表的主鍵是36位的UUID,用以下語句語句插入數據是否會出現重復主鍵
不會重復,你都使用newid函數了,每次會自動生成不同的uuid的
Ⅵ uuid生成隨機字元串的sql怎麼寫
在SQLServer中使用該sql語句可以生成GUID:select cast(NEWID() as varchar(36)) as uuid
通過一下語句將GUID中的'-'字元去掉:
select SUBSTRING(uuid,1,8)+SUBSTRING(uuid,10,4)+SUBSTRING(uuid,15,4)+
SUBSTRING(uuid,20,4)+SUBSTRING(uuid,25,12) from (select cast(NEWID() as varchar(36)) as uuid ) s
在oracle中使用select sys_guid() from al;可以獲得guid。
Ⅶ plsql 導入excel,那表中的uuid 生成的id怎麼處理
題目有點不明確
可以選擇該列 右鍵操作
特別說明:
1.excel不能存儲 以0開頭的值
2.解決的辦法就是設置該列為 文本就可以保存0開頭的值
Ⅷ mysql創建資料庫時怎麼將主鍵設置為UUID,建表語句怎麼寫
mysql設置UUID為主鍵需要先將數據類型設置為VARCHAR(36),然後插入數據的時候用UUID函數插入UUID。下面我用win10系統下的CMD命令行具體演示一下:
1、打開CMD,輸入mysql -uroot -p命令連接mysql,如下圖所示
Ⅸ mysql批量插入uuid的SQL語句是什麼
update test set id = UUID();MYSQL無法在默認值中設置UUID函數,實際上其它函數除TIMESTAMP之外都不可以。 MYSQL的默認值目前只能是常數或者CURRENTTIMESTAMP。
如果需要實現UUID為默認值的功能,則可以在該表的INSERT觸發器中實現:
update test set id = UUID();
create TRIGGER test_insert
AFTER INSERT ON test
FOR each ROW
BEGIN
update test set id = UUID();
end;
不過一般主鍵id都用AUTO_INCREMENT,uuid()不適合做主鍵
Ⅹ 在sql server裡面如何使用UUID
因為考慮到未來數據量的問題,肯定是需要做集群的,並且有的表在大並發的情況下,Insert操作比較多。因此考慮使用UUID作主鍵。
現在有兩個疑問:
第一個就是UUID做主鍵肯定會增大存儲空間,這些空間倒無所謂,但Innodb會為主鍵建立索引,所以會不會導致索引太大(32位字元主鍵),導致索引太大而導致查詢速度下降
第二個就是MS SQL的UUID()函數比 java.util.UUID產生UUID比使用更好