Mysql學習第二天

来源:https://www.cnblogs.com/java0619/archive/2018/01/26/8358206.html
-Advertisement-
Play Games

DDL 資料庫定義語言(庫的操作)(看懂,工作時使用較少)1.創建一個庫 create database 庫名稱 [character set 碼表名稱 collate 字元校對集名稱] create database day15; 1>看到Query OK, 1 row affected (0.0 ...


DDL 資料庫定義語言(庫的操作)(看懂,工作時使用較少)
1.創建一個庫
         create database 庫名稱 [character set 碼表名稱 collate 字元校對集名稱]
         create database day15;
        1>看到Query OK, 1 row affected (0.00 sec) 表示執行成功.
        2>sql語句語法: 結尾應使用";"號.
        3>字元校對集: 決定數據排序的。
2.顯示mysql中都有哪些庫了.
        show databases;
        +--------------------+
        | Database |
        +--------------------+
        | information_schema |
        | day13 |
        | mysql |
        | performance_schema |
        | test |
        +--------------------+
        可以看到除了自己創建的庫之外,還有一些其他庫。其他庫(除了test)不要亂動。因為是保存mysql的配置信息,賬戶信息等等。
        test庫 : 自動創建用於測試的。
3.刪除一個數據
        drop database 資料庫名稱;
        drop database day15;
4.修改資料庫碼表和字元校對(不常用)
        alter database 資料庫名稱 character set 資料庫碼表 [collate 校對集名稱];
        alter database day15 character set utf8 collate utf8_bin;
5.當前要使用的庫(重要)
        use 庫名
        use day15;
        出現Database changed,說明切換完成.
6.查看當前選擇的資料庫
        select database();
        +------------+
        | database() |
        +------------+
        | day15 |
        +------------+
7.顯示創建庫的語句.
        show create database 資料庫名稱;
        show create database day15;
        | day15 | CREATE DATABASE `day15` /*!40100 DEFAULT CHARACTER SET utf8 COLLATE
        utf8_bin */ |
//-------------------------------------------------------------------------------------------------------------------------------------------------------
資料庫中的數據類型 (瞭解,知道在什麼情況下應該使用什麼類型的數據)
一。數字型
        整型
         TINYINT 1位元組 byte
         SMALLINT 2位元組 short
         MEDIUMINT 3位元組
         (常用)INT 4位元組 int
         BIGINT 8位元組 long
        浮點型
         FLOAT 單精度4位元組 float
         **DOUBLE 8位元組 double
         *DECIMAL 沒有精度損失
============================================
        DOUBLE 和 DECIMAL 區別?
         DOUBLE類型在運算時會有精度的缺失。
         DECIMAL 就是解決精度缺失問題的。(底層使用字元串來保存數字)
         單純想表示小數屬性時,使用double。
         需要頻繁參與運算的小數,使用decimal。
============================================
二。字元串類型
 註意: 字元串類型要使用單引號包裹.
        短字元串類型
        CHAR/VARCHAR (最大長度255位元組)
====================================================
問題:char和varchar有什麼區別?
         char定長字元串.varchar表示變長字元串.
         同時指定長度為10。當存儲 abc
         char => 'abc '
         varchar => 'abc'
結論: 開發中varchar用的最多。 char只在表示固定長度的枚舉中使用。例如 :性別(用01,02表示)
====================================================
長字元串類型(流類型)
      *TEXT/CLOB 保存文本(字元流) --> 當要保存的內容超過255位元組時使用. java中的writer 字元
      BLOB 保存位元組(位元組流) --> 開發中用不到 java中的stream 位元組
   Character Large Object
   binary Large Object
 區別:
      text:只能存儲字元數據.
      BLOB:可以存儲字元和多媒體信息(圖片 聲音 圖像)
三、日期和時間類型
        date 只記錄日期 2015-01-14
        time 只記錄時間 11:36:25
        year 只記錄年 2015
        datatime 又記錄日期 又記錄 時間 2015-01-14 11:36:25
**timestamp 同上 2015-01-14 11:36:25
   問題: datatime 和 timestamp 區別?
         這兩種類型記錄的數據是一模一樣.
         區別在於插入的時候,如果插入datatime類型時,沒有 傳值,那麼該類型預設值就是null;
         如果插入timestamp類型時,沒有 傳值,那麼該類型預設值就是當前時間;
//--------------------------------------------------------------------------;----------------------------------------
與創建表相關的語句(DDL) (記住,能夠手寫)
      CREATE TABLE table_name
      (
      field1 datatype 約束/主鍵約束 auto_increment,
      field2 datatype 約束,
      field3 datatype 約束
      )character set 字元集 collate 校對規則
1.創建表
      create table t_user(
      name varchar(10),
      password varchar(20),
      age int(3), -- 數字類型在聲明時,可以忽略長度.
      birthday datetime,
      hiredate timestamp
      );
varchar最好指定長度
整型一般不指定.
2.查看當前庫中有哪些表
        show tables;
3.查看表的結構
        desc 表名;
        desc t_user;
4.刪除表
        drop table 表名;
        drop table t_user;
5.添加一列
        alter table 表名 add 列名 類型;
        alter table t_user add photo blob;
6.修改列的類型
        alter table 表名 modify 列名 類型;
        alter table t_user modify photo varchar(20);
7.修改列的名稱
        alter table 表名 change 舊列名 新列名 數據類型;
        將 photo這一列 改名為 image
        alter table t_user change photo image varchar(20);
8.刪除某列
        alter table 表名 drop 列名;
        alter table t_user drop image;
9.修改表的名稱
        rename table 舊表名 to 新名;
        rename table t_user to user;
10(用的極少)修改表的字元集. (如果創建表時不指定,預設使用資料庫的字元集)
        alter table 表名 character set 字元集 collate 校對集;
        alter table t_user character set utf8 collate utf8_bin;
//-------------------------------------------------------------------------------------------------
列的約束 (掌握)
保證數據的完整性的.
1.非空約束(not null) 指定非空約束的列, 在插入記錄時 必須包含值.
2.唯一約束(unique) 該列的內容在表中. 值是唯一的.
3.主鍵約束(primary key) 當想要把某一列的值,作為該列的唯一標示符時,可以指定主鍵約束(包含 非空約束和唯一約束). 一個表中只能指定一個主鍵約束列.
主鍵約束 , 可以理解為 非空+唯一.
註意: 並且一張表中只能有一個主鍵約束.
約束體現資料庫的完整性.
例如:創建帶有約束的表
create table t_user2(
id int primary key auto_increament, -- 員工編號
name varchar(10) not null, -- 員工姓名
loginname varchar(10) not null unique, -- 登陸名稱
password varchar(20) not null, -- 密碼
age int(3) not null, -- 年齡
birthday datetime not null, -- 生日
hiredate timestamp not null -- 入職日期
);
//----------------------------------------------------------------------------------------------------------------------------
主鍵自動增長 (掌握)

註意:
1.前提某個表的主鍵是數字. 我們可以將該主鍵設置為自增.
2.使用主鍵自增可能會造成主鍵的斷層。
3.mysql,sqlserver這兩個資料庫具有該功能.
4.主鍵自增只能給主鍵約束的列加。
自增就是 每次插入記錄時不需要指定值. 該欄位自己維護自己的值.
維護方式就是每次加1;
語法:
create table t_user(
id int primary key auto_increment,
password varchar(30) not null,
age int not null,
birthday datetime not null,
hiredate timestamp not null,
number int unique
);
//--------------------------------創建修改表練習---------------------------------------------------
CREATE TABLE employee (
id INT(10),
NAME VARCHAR(10),
gender VARCHAR(10),
birthday DATETIME,
entry_date TIMESTAMP,
job VARCHAR(5),
salary DOUBLE(5,3),
RESUME TEXT
);

1在上面員工表的基礎上增加一個image列。

        alter table employee add image blob;

2修改job列,使其長度為60。

        alter table employee modify job varchar(60)'

3刪除gender列。

        alter table employee drop gender;

4表名改為user。

        rename table employee to user;

5修改表的字元集為utf8
6列名name修改為username
        alter table employee change name username varchar(20);

//----------------------------------對錶中數據的增刪改(DML)-------------------------------------------------------------------
create table t_user(
id int primary key auto_increment,
name varchar(20) not null,
email varchar(20) unique
)


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

-Advertisement-
Play Games
更多相關文章
  • Oracle導出導入表(.sql、.dmp文件)兩種方法 方法一:.sql文件的導出與導入 導出步驟 使用PL/SQL Developer登錄你需要備份的資料庫; 選擇工具->導出用戶對象; 在對象列表中選擇需要備份的對象,再選擇一個sql類型的輸出文件,點擊【導出】,這隻是導出數據結構; 選擇工具 ...
  • 運營平臺至少要連三個庫:運營庫,A庫,B庫,並且希望達到針對每個功能請求能夠自動切換到對應的數據源(我最終實現是針對Service的方法級別進行切換的,也可以實現針對每個DAO層的方法進行切換。我們系統的功能是相互之間比較獨立的)。 ...
  • 工具/原料 工具/原料 PLSQL 方法/步驟 1.在PLSQL里,用system/css(orcl系統用戶)登陸,登陸的時候普通用戶登陸選擇normal就可以了 方法/步驟 1.在PLSQL里,用system/css(orcl系統用戶)登陸,登陸的時候普通用戶登陸選擇normal就可以了 2.Or ...
  • 1 ALTER TABLE 'table_name' DROP 'id'; 2 ALTER TABLE 'table_name' ADD 'id' int(11) PRIMARY KEY NOT NULL AUTO_INCREMENT FIRST; ...
  • 前言 最近在嘗試一個日誌系統graylog來收集mysql的慢查詢日誌提,供後續的分析、監控和報警等。測試步驟已經到日誌已成功收集到graylog,測試時需要刷一些慢查詢日誌出來。為了刷比較多的日誌和不對測試環境造成較大的影響,想到了使用mysql的sleep函數結合event來做刷慢日誌。 MyS ...
  • 一、基本查詢 (表:emp 列:ename ,depton,sal 、表示換行) 1.查當前用戶 SQL> show user 2.查表結構 SQL> desc emp (emp:表名) --查詢出名稱、類型、是否為空 3.清屏 SQL> host cls 4.設置行寬 SQL> show line ...
  • 轉載地址為:http://blog.51cto.com/hades02/1641652 首先在命令行輸入 show global variables like '%general%' ,然後出現下麵的視窗,欄位general_log為開關,一般預設是為OFF的,所以還沒開啟監視,然後general_ ...
  • Redis簡介 Redis是一個開源的使用ANSI C語言編寫、支持網路、可基於記憶體亦可持久化的日誌型、Key-Value資料庫,並提供多種語言的API. Redis是一個開源(BSD許可),記憶體存儲的數據結構伺服器,可用作資料庫,高速緩存和消息隊列代理。它支持字元串、哈希表、列表、集合、有序集合, ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...