国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

達夢數(shù)據(jù)庫(DM8)常用SQL學(xué)習(xí)

這篇具有很好參考價值的文章主要介紹了達夢數(shù)據(jù)庫(DM8)常用SQL學(xué)習(xí)。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

達夢產(chǎn)品手冊

1.檢查數(shù)據(jù)庫版本及服務(wù)狀態(tài)

1.1 查看達夢數(shù)據(jù)庫運行狀態(tài)

SELECT status$ as 狀態(tài) FROM v$instance;

達夢數(shù)據(jù)庫(DM8)常用SQL學(xué)習(xí)

1.2 查看達夢數(shù)據(jù)庫版本

SELECT banner as 版本信息 FROM v$version;

達夢數(shù)據(jù)庫(DM8)常用SQL學(xué)習(xí)

2.創(chuàng)建用戶并授權(quán)

2.1 創(chuàng)建用戶

-- 使用 CREATE USER 語句創(chuàng)建 DM 用戶,登錄密碼為 "dameng123"。
CREATE USER DM IDENTIFIED BY "dameng123";

2.2 授予用戶基本權(quán)限

-- 使用GRANT語句給DM用戶授予RESOURCE角色
GRANT RESOURCE TO DM;
-- 給 DM 用戶授予 dmhr 用戶下 employee 表的 select 權(quán)限;
GRANT SELECT ON dmhr.employee TO DM;
-- 給 DM 用戶授予 dmhr 用戶下 department 表的 select 權(quán)限;
GRANT SELECT ON dmhr.department TO DM;
-- 給 DM 用戶授予 創(chuàng)建表的權(quán)限
GRANT CREATE TABLE to DM;

2.3 查看用戶信息

-- 通過字典表 dba_users 查看基本信息
SELECT username,account_status,created FROM dba_users WHERE username='DM';

從輸出結(jié)果看出,用戶狀態(tài) account_status 為 open,輸出的時間為用戶的創(chuàng)建時間。
達夢數(shù)據(jù)庫(DM8)常用SQL學(xué)習(xí)

2.4 切換用戶

-- 使用 conn 命令切換用戶。
conn DM/dameng123;

注意:windows系統(tǒng)在DM管理工具中使用該命令無法完成用戶切換,直接斷開登錄后重新連接,更換登錄用戶即可。

-- 使用 user 關(guān)鍵字返回當前登錄用戶。
SELECT user FROM DUAL;

3. 表相關(guān)

3.1創(chuàng)建表并添加約束

-- 創(chuàng)建employee表
CREATE TABLE employee
(
  employee_id INTEGER,
  employee_name VARCHAR2(20) NOT NULL,
  hire_date DATE,
  salary INTEGER,
  department_id INTEGER NOT NULL
);
-- 使用 CREATE TABLE 語句創(chuàng)建 department 表
CREATE TABLE department
(
  department_id INTEGER PRIMARY KEY,
  department_name VARCHAR(30) NOT NULL
);
-- 非空約束
ALTER TABLE employee MODIFY( hire_date not null);
-- 主鍵約束
ALTER TABLE employee ADD constraint pk_empid PRIMARY KEY(employee_id);
-- 外鍵約束
ALTER TABLE employee ADD constraint fk_dept FOREIGN KEY (department_id) REFERENCES department (department_id);

3.2 查看表主鍵外鍵

SELECT table_name, constraint_name, constraint_type FROM all_constraints WHERE owner='DM' AND table_name='EMPLOYEE';

3.3 表字段增加

ALTER TABLE "DM"."EMPLOYEE" add "IS_REPEAT" VARCHAR(255);
COMMENT ON COLUMN "DM"."EMPLOYEE"."IS_REPEAT" IS '是否重復(fù),1、是,0、否';

3.4 表字段刪除

ALTER TABLE "DM"."EMPLOYEE" DROP COLUMN IS_REPEAT;

4. 驗證數(shù)據(jù)表 CRUD 功能

-- 插入數(shù)據(jù)
INSERT INTO department VALUES(666, '數(shù)據(jù)庫產(chǎn)品中心');
INSERT INTO employee VALUES (9999, '王達夢','2008-05-30 00:00:00', 30000, 666);
commit;
-- 因為 employee 員工表和 department 部門表存在主外鍵約束,所以此示例中須按順序執(zhí)行插入語句,即先在 department 表中插入數(shù)據(jù)。

-- 更新數(shù)據(jù)
UPDATE employee SET salary='35000' WHERE employee_id=9999;
commit;

-- 驗證數(shù)據(jù)
SELECT salary,employee_id FROM employee;

-- 刪除數(shù)據(jù)
DELETE FROM employee;
DELETE FROM department WHERE department_id=666;
commit;

-- 驗證數(shù)據(jù)
SELECT * FROM employee;

5. 批量插入及選擇排序

-- 在 t1 表中批量插入 100000 條數(shù)據(jù)記錄。
CREATE TABLE t1 AS
     SELECT rownum AS id,
       trunc(dbms_random.value(0, 100)) AS random_id,
       dbms_random.string('x', 20) AS random_string
     FROM dual
     connect BY level <= 100000;
-- 使用 COUNT(*) 聚集函數(shù)統(tǒng)計 t1 表中的總數(shù)據(jù)記錄。
SELECT COUNT(*) FROM t1;
-- 使用 ORDER BY 語句實現(xiàn)選擇排序。
SELECT * FROM t1 where rownum<5 ORDER BY id DESC;

6.驗證分組查詢

-- 插入準備數(shù)據(jù)
INSERT INTO department (department_id, department_name)
     SELECT department_id, department_name FROM dmhr.department;
INSERT INTO employee
     (employee_id, employee_name, hire_date, salary, department_id)
     SELECT employee_id, employee_name, hire_date, salary,
     department_id FROM dmhr.employee;
commit;
SELECT dept.department_name as 部門, count(*) as 人數(shù)
     FROM employee emp, department dept
     where emp.department_id=dept.department_id
     GROUP BY dept.department_name
     HAVING count(*) > 20;

7.創(chuàng)建視圖

-- 定義視圖
CREATE OR replace VIEW v1 AS
     SELECT dept.department_name, emp.employee_name,
     emp.salary,emp.hire_date
     FROM employee emp, department dept
     WHERE salary > 10000
     AND hire_date >= '2013-08-01'
     AND emp.department_id = dept.department_id;
-- 通過視圖簡化查詢
 SELECT * FROM v1 WHERE hire_date > '2014-09-01';

8.索引

-- 創(chuàng)建普通索引
CREATE INDEX ind_emp_salary ON employee(salary);
SELECT table_name, index_name, index_type
     from user_indexes WHERE index_name='IND_EMP_SALARY';
-- 刪除索引
DROP INDEX IND_EMP_SALARY;

9.創(chuàng)建表

-- 若該表存在則刪除
DROP TABLE IF EXISTS TEST_TEMP; 
-- 創(chuàng)建對應(yīng)的表:
-- 主鍵自增配置  IDENTITY(1, 1),CLUSTER PRIMARY KEY("ID")
-- 自動創(chuàng)建時間  DEFAULT (CURDATE)
CREATE TABLE "TEST_TEMP"
(
"ID" INT IDENTITY(1, 1) NOT NULL,
"PROJECT_KEY" 	VARCHAR(100), 
"CREAT_TIME" 	DATE 			DEFAULT (CURDATE),
CLUSTER PRIMARY KEY("ID"))
STORAGE(ON "TEST", CLUSTERBTR) ;

9.1 批量插入數(shù)據(jù)

-- 語法
SET IDENTITY_INSERT [<模式名>.]<表名> ON | OFF;
-- 初始化數(shù)據(jù),自增id賦值。需要指定列且IDENTITY_INSERT設(shè)置ON
SET IDENTITY_INSERT SYSDBA.TEST_TEMP ON;
INSERT INTO TEST_TEMP(ID,PROJECT_KEY,CREAT_TIME) VALUES (1, '測試項目', '2022-12-15 14:15:30');
-- 記得提交,否則無法真正的落庫。
commit;

9.2 數(shù)據(jù)庫自動新增日期

-- 自動生成日期,不帶時分秒
"CREAT_TIME" 	DATE 			DEFAULT (CURDATE),
-- 自動生成日期,帶時分秒
"CREAT_TIME" 	TIMESTAMP 		DEFAULT (SYSDATE),

9.3 數(shù)據(jù)庫自動更新時間

通過觸發(fā)器腳本實現(xiàn)

create trigger UPDATE_TIME_CUSTOM_NAME
before update on "DEV"."CUSTOM_NAME" for each row
begin
new.UPDATE_TIME:=sysdate;
end;

解析
UPDATE_TIME_CUSTOM_NAME:觸發(fā)名稱
DEV: 模式名
CUSTOM_NAME:表名稱
UPDATE_TIME:字段名稱
– 字段配置,自動生成日期,帶時分秒
“UPDATE_TIME” TIMESTAMP DEFAULT (SYSDATE),

10. 查詢表中的字段信息

-- SYSDBA為模式,TEST_TEMP 為表名稱
-- 查詢表字段情況,但不包含注釋信息
select * from all_tab_columns where owner='SYSDBA' and Table_Name='TEST_TEMP'

達夢數(shù)據(jù)庫(DM8)常用SQL學(xué)習(xí)

-- 查詢表字段的注釋信息
select * from dba_col_comments  where owner='SYSDBA' and Table_Name='TEST_TEMP'

達夢數(shù)據(jù)庫(DM8)常用SQL學(xué)習(xí)文章來源地址http://www.zghlxwxcb.cn/news/detail-428468.html

11.修改字段

11.1 修改字段名稱及注釋

-- 將SYSDBA模式的TEST_TEMP表中的UPDATE_TIME字段名稱修改為CREATE_TIME
ALTER TABLE  "SYSDBA"."TEST_TEMP"  RENAME COLUMN "UPDATE_TIME" TO "CREATE_TIME";
COMMENT ON COLUMN "SYSDBA"."TEST_TEMP"."CREATE_TIME" IS '數(shù)據(jù)創(chuàng)建時間';

11.2 修改字段類型

-- 將SYSDBA模式的TEST_TEMP表中的CREATE_TIME 字段類型修改為TIMESTAMP DEFAULT SYSDATE
ALTER TABLE "SYSDBA"."TEST_TEMP" MODIFY CREATE_TIME TIMESTAMP DEFAULT SYSDATE

到了這里,關(guān)于達夢數(shù)據(jù)庫(DM8)常用SQL學(xué)習(xí)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔相關(guān)法律責任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • 開發(fā) | JAVA連接達夢數(shù)據(jù)庫(DM8)

    開發(fā) | JAVA連接達夢數(shù)據(jù)庫(DM8)

    本文參考文獻 https://eco.dameng.com/docs/zh-cn/start/java-development.html https://eco.dameng.com/docs/zh-cn/app-dev/index.html 本文通過以下方式實現(xiàn)Java程序與DM8數(shù)據(jù)庫的交互 使用JDBC接口(不用框架,最簡單) 使用MyBatis框架 使用Spring框架 使用SpringBoot Jdbc 框架 Java的軟件開發(fā)工具包(SDK) JDK(Ja

    2024年02月07日
    瀏覽(31)
  • dmfldr-快速裝載-載入(DM8:達夢數(shù)據(jù)庫)

    DM 提供了快速裝載工具:dmfldr; 通過使用快速裝載工具能夠把按照一定格式排序的文本數(shù)據(jù)以簡單、快速、高效的方式載入到 DM 數(shù)據(jù)庫中,或把 DM 數(shù)據(jù)庫中的數(shù)據(jù)按照一定格式載出到文本文件中。 dmfldr 在一臺機器上啟動即可,獨立完成快速裝載任務(wù),簡單高效。 其中,表

    2024年02月06日
    瀏覽(22)
  • springboot使用達夢數(shù)據(jù)庫(DM8)整合MybatisPlus

    springboot使用達夢數(shù)據(jù)庫(DM8)整合MybatisPlus

    在idea中開發(fā)spring boot項目,用到的數(shù)據(jù)庫是達夢數(shù)據(jù)庫,想要使用 MybatisPlus 自動生成實體類和服務(wù),并且通過 MybatisPlus 完成一些簡單的數(shù)據(jù)庫CRUD ps:這里的 MybatisPlus 版本必須要是3.0以上 2.1、pom ps:其中需要將達夢數(shù)據(jù)庫的依賴添加到指定目錄下,不然達夢的依賴無法生效

    2024年02月16日
    瀏覽(27)
  • Linux安裝達夢數(shù)據(jù)庫/DM8(附帶客戶端工具安裝完整版)

    Linux安裝達夢數(shù)據(jù)庫/DM8(附帶客戶端工具安裝完整版)

    1.1、創(chuàng)建安裝與運行的Linux用戶 官方也明確提出,為了減少對操作系統(tǒng)的影響, Linux 用戶不應(yīng)該已 root 用戶和默認的用戶組來安裝與運行達夢數(shù)據(jù)庫,應(yīng)該為 DM 創(chuàng)建一個專用的用戶組和系統(tǒng)用戶。例如: 1.2、操作系統(tǒng)資源限制檢查 這也是官方給出的提醒,在 Linux 系統(tǒng)中,

    2024年02月02日
    瀏覽(35)
  • -9501 MAL系統(tǒng)沒有配置或者服務(wù)器不是企業(yè)版(dm8達夢數(shù)據(jù)庫)

    -9501 MAL系統(tǒng)沒有配置或者服務(wù)器不是企業(yè)版(dm8達夢數(shù)據(jù)庫)

    搭建主備集群時,遇到報錯-9501 MAL系統(tǒng)沒有配置或者服務(wù)器不是企業(yè)版 檢查dmmal.ini配置文件權(quán)限正確 dmdba:dinstall,內(nèi)容正確 檢查dm.key授權(quán)是支持主備或讀寫分離 檢查dm.ini 參數(shù)配置 最終定位問題是 dm.ini 中 INSTANCE_NAME 參數(shù)值 與dmmal.ini 中MAL_INST_NAME 不匹配的原因,修改后啟動

    2024年02月11日
    瀏覽(47)
  • 麒麟操作系統(tǒng)Kylin V10 安裝達夢數(shù)據(jù)庫DM8 客戶端遠程調(diào)試

    麒麟操作系統(tǒng)Kylin V10 安裝達夢數(shù)據(jù)庫DM8 客戶端遠程調(diào)試

    一、環(huán)境準備 軟件名稱 版本 vmware workstation 16.1.2 build-17966106 銀河麒麟 Kylin-Server-10-SP2-x86-Release-Build09-20210524.iso 達夢DM8 DMInstall.bin 銀河麒麟 server v10 x86架構(gòu)安裝iso鏡像。 Kylin-Server-10-SP2-x86-Release-Build09-20210524.iso 二、DM8數(shù)據(jù)庫安裝 以下操作可以使用遠程工具執(zhí)行命令 1. 啟動網(wǎng)絡(luò)

    2024年02月04日
    瀏覽(37)
  • 配置ODBC驅(qū)動連接DM8數(shù)據(jù)庫

    配置ODBC驅(qū)動連接DM8數(shù)據(jù)庫

    ODBC提供訪問不同類型的數(shù)據(jù)庫的途徑。結(jié)構(gòu)化查詢語言 SQL 是一種用來訪問數(shù)據(jù)庫的語言。通過使用 ODBC,應(yīng)用程序能夠使用相同的源代碼和各種各樣的數(shù)據(jù)庫交互。這使得開發(fā)者不需要以特殊的數(shù)據(jù)庫管理系統(tǒng) DBMS 為目標,或者了解不同支撐背景的數(shù)據(jù)庫的詳細細節(jié),就能

    2024年02月16日
    瀏覽(27)
  • 達夢(DM)數(shù)據(jù)庫存儲加密

    達夢(DM)數(shù)據(jù)庫存儲加密

    這里主要講述DM數(shù)據(jù)庫存儲加密中比較常用也比較容易理解的非透明加密相關(guān)內(nèi)容。 引用官方的話說:DM 對非透明加密的支持是通過對用戶提供加解密接口實現(xiàn)的。用戶在使用非透明加密時,需要提供密鑰并調(diào)用加解密接口。采用非透明加密可以保證個人私密數(shù)據(jù)不被包括

    2024年04月29日
    瀏覽(28)
  • 【DM】達夢數(shù)據(jù)庫與MySQL適配

    【DM】達夢數(shù)據(jù)庫與MySQL適配

    新手直接看達夢入門技術(shù)文檔即可 1、介紹 達夢數(shù)據(jù)庫管理系統(tǒng)是達夢公司推出的具有完全自主知識產(chǎn)權(quán)的高性能數(shù)據(jù)庫管理系統(tǒng),簡稱DM,它具有如下特點: 通用性、高性能、高可用、跨平臺、高可擴展 2、與MySQL的區(qū)別 (1)創(chuàng)建表的時候,不支持在列的后面直接加 comme

    2024年02月14日
    瀏覽(23)
  • SSH項目集成DM達夢數(shù)據(jù)庫

    SSH項目集成DM達夢數(shù)據(jù)庫

    接上一篇文章【Mysql數(shù)據(jù)庫遷移到達夢DM】,遷移完成后,做出的調(diào)整 目錄 1.需要改成DM的連接數(shù)據(jù)的方式 2.啟動項目報錯 3.在做插入數(shù)據(jù)操作時報錯 1.需要改成DM的連接數(shù)據(jù)的方式 2.啟動項目報錯 報錯內(nèi)容如下圖 原因:沒有連接上數(shù)據(jù)庫,連接數(shù)據(jù)缺了compatibleMode=oracle,就

    2024年02月10日
    瀏覽(31)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包