達夢產(chǎn)品手冊
1.檢查數(shù)據(jù)庫版本及服務(wù)狀態(tài)
1.1 查看達夢數(shù)據(jù)庫運行狀態(tài)
SELECT status$ as 狀態(tài) FROM v$instance;
1.2 查看達夢數(shù)據(jù)庫版本
SELECT banner as 版本信息 FROM v$version;
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)建時間。
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'
文章來源:http://www.zghlxwxcb.cn/news/detail-428468.html
-- 查詢表字段的注釋信息
select * from dba_col_comments where owner='SYSDBA' and Table_Name='TEST_TEMP'
文章來源地址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)!