【数据库】达梦数据库下载、安装、底子与高级语法,以及与其他数据库的区别 ...

西河刘卡车医  金牌会员 | 2024-10-24 08:25:49 | 来自手机 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 910|帖子 910|积分 2730



  
更多相干内容可查看
达梦数据库(DM Database)是一款国产数据库,比年来渐渐受到关注。它兼容 Oracle 数据库,但与 MySQL 和 Oracle 在 SQL 语法和功能实现上存在一些差别。
一、达梦数据库下载

官网下载地址:https://www.dameng.com/DM8.html

CPU选X86,操作系统选win64


二、达梦数据库安装

解压并打开光盘映像文件,双击setup.exe

选择语言与时区

无脑下一步即可


这里key可以不选

这里可以按需选择

选择安装路径(必须为空)


三、创建数据库

找到tool路径下的dbca,第一次安装也可以直接初始化

初始化

创建数据库实例


这里是创建一个放数据的目录


这里的控制文件/数据文件/日志文件/初始化文件都会有对应的路径

这里可以按需设置一些信息

这里是用户名跟暗码

这里两项可以勾选也可不勾选(按需选择)



四、达梦数据库的客户端使用

找到tool文件下的manager,即可使用,如果之前用过navicat,或者别的,其实都差不多,目录布局可看官方文档,这里不做论述

五、达梦数据库的根本语法

1. 数据库对象的创建与管理
创建数据库
  1. CREATE DATABASE my_database;
复制代码
创建表
  1. CREATE TABLE employees (
  2.     employee_id INT PRIMARY KEY,
  3.     first_name VARCHAR(50),
  4.     last_name VARCHAR(50),
  5.     hire_date DATE,
  6.     salary DECIMAL(10, 2)
  7. );
复制代码
修改表布局
  1. -- 添加新列
  2. ALTER TABLE employees ADD department VARCHAR(50);
  3. -- 修改列的数据类型
  4. ALTER TABLE employees MODIFY salary DECIMAL(12, 2);
复制代码
删除表
  1. DROP TABLE employees;
复制代码
2. 数据操作
插入数据
  1. INSERT INTO employees (employee_id, first_name, last_name, hire_date, salary)
  2. VALUES (1, 'John', 'Doe', '2024-01-15', 50000.00);
复制代码
查询数据
查询数据使用 SELECT 语句。达梦数据库支持多种查询方式,包括简朴查询、条件查询和连接查询:
  1. -- 查询所有数据
  2. SELECT * FROM employees;
  3. -- 条件查询
  4. SELECT * FROM employees WHERE salary > 40000;
  5. -- 连接查询
  6. SELECT e.first_name, e.last_name, d.department_name
  7. FROM employees e
  8. JOIN departments d ON e.department_id = d.department_id;
复制代码
更新数据
  1. UPDATE employees
  2. SET salary = salary * 1.05
  3. WHERE hire_date < '2023-01-01';
复制代码
删除数据
  1. DELETE FROM employees WHERE employee_id = 1;
复制代码

六、达梦数据库的高级语法

1. 视图与索引
创建视图
视图是一个虚拟表,它基于 SQL 查询的结果集。在达梦数据库中,可以通过以下语法创建视图:
  1. CREATE VIEW high_salary_employees AS
  2. SELECT first_name, last_name, salary
  3. FROM employees
  4. WHERE salary > 50000;
复制代码
使用视图
查询视图数据的方式与查询表数据相同:
  1. SELECT * FROM high_salary_employees;
复制代码
创建索引
索引可以进步查询性能。在达梦数据库中,可以通过以下语法创建索引:
  1. CREATE INDEX idx_salary ON employees (salary);
复制代码
2. 存储过程与触发器
创建存储过程
存储过程是一组 SQL 语句的聚集,可以重复使用。以下是一个存储过程的示例:
  1. CREATE PROCEDURE increase_salary(IN percentage DECIMAL(5, 2))
  2. BEGIN
  3.     UPDATE employees
  4.     SET salary = salary * (1 + percentage / 100);
  5. END;
复制代码
调用存储过程
调用存储过程时,需要指定输入参数:
  1. CALL increase_salary(10);
复制代码
创建触发器
触发器是在表的某些事件(如插入、更新、删除)发生时自动执行的存储过程。以下是一个触发器的示例:
  1. CREATE TRIGGER salary_update_trigger
  2. AFTER UPDATE ON employees
  3. FOR EACH ROW
  4. BEGIN
  5.     IF NEW.salary > OLD.salary THEN
  6.         INSERT INTO salary_audit (employee_id, old_salary, new_salary, update_date)
  7.         VALUES (NEW.employee_id, OLD.salary, NEW.salary, SYSDATE);
  8.     END IF;
  9. END;
复制代码
3. 数据库事件与锁
事件管理
达梦数据库支持事件的开始、提交和回滚。以下是事件的根本操作:
  1. -- 开始事务
  2. START TRANSACTION;
  3. -- 执行多个 SQL 语句
  4. UPDATE employees SET salary = salary + 1000 WHERE employee_id = 1;
  5. -- 提交事务
  6. COMMIT;
  7. -- 回滚事务
  8. ROLLBACK;
复制代码
锁管理
达梦数据库提供了多种锁机制,包括行级锁和表级锁。锁的使用可以通过 SQL 语句设置:
  1. -- 行级锁
  2. SELECT * FROM employees WHERE employee_id = 1 FOR UPDATE;
  3. -- 表级锁
  4. LOCK TABLE employees IN EXCLUSIVE MODE;
复制代码

七、与其他数据库的比较

1. 达梦与 MySQL
   数据库对象创建
  

  • 达梦数据库:支持 CREATE DATABASE 和 CREATE TABLE,语法类似于 Oracle。
  • MySQL:也支持 CREATE DATABASE 和 CREATE TABLE,但在数据类型和默认值上可能有差别。
  数据操作
  

  • 达梦数据库:SQL 语法与 Oracle 更为靠近,例如支持 TO_DATE 函数来处理日期。
  • MySQL:使用 STR_TO_DATE 函数来处理日期,函数名称和语法与达梦有所不同。
  索引与视图
  

  • 达梦数据库:支持视图和索引的创建和管理,语法与 Oracle 相似。
  • MySQL:支持视图和索引,语法上也有些许差别。例如,MySQL 不支持索引的 CREATE INDEX 语法中的某些选项。
  2. 达梦与 Oracle
   数据库对象创建
  

  • 达梦数据库:与 Oracle 非常相似,包括数据类型和束缚的设置。
  • Oracle:支持更多的数据类型和复杂的束缚设置。
  存储过程与触发器
  

  • 达梦数据库:存储过程和触发器的创建语法与 Oracle 根本一致。
  • Oracle:提供了更多的 PL/SQL 功能和优化选项,例如复杂的异常处理和游标操作。
  事件管理
  

  • 达梦数据库:支持标准的事件控制语句,如 START TRANSACTION 和 COMMIT。
  • Oracle:使用 BEGIN 和 END 来定义事件块,但语法上与达梦数据库相似。
  3. 达梦与 SQL Server
   数据库对象创建
  

  • 达梦数据库:支持 SQL 标准的 CREATE DATABASE 和 CREATE TABLE。
  • SQL Server:使用 CREATE DATABASE 和 CREATE TABLE,但数据类型和默认值的定义有所不同。
  存储过程与触发器
  

  • 达梦数据库:创建存储过程和触发器的语法类似于 Oracle。
  • SQL Server:使用 T-SQL 进行存储过程和触发器的创建,语法上有明显的差别。
  事件管理
  

  • 达梦数据库:使用标准的 SQL 事件控制语句。
  • SQL Server:支持 BEGIN TRANSACTION 和 COMMIT,但在异常处理和锁定策略上有其特定的实现。
  
八、优势体现

1. 性能
   

  • 高性能查询处理:达梦数据库通过优化的查询处理器和执行筹划算法,可以或许高效地处理大规模的数据查询。它支持各种索引机制,如B-Tree索引、位图索引等,有助于进步查询性能。
  • 支持并行处理:达梦数据库支持并行盘算,可以在多核处理器上同时执行多个任务,从而加快数据处理速度。
  • 数据缓存和内存管理:达梦数据库通过有效的缓存机制和内存管理来进步系统的响应速度和处理能力。例如,它会缓存热门数据,以减少磁盘I/O操作。
  • 事件处理能力:达梦数据库支持高并发的事件处理,采用了高效的锁机制和日志管理,确保了在高负载下也能保持良好的性能。
  2. 安全性
   

  • 用户权限管理:达梦数据库提供了细粒度的权限管理功能,可以对不同的用户和脚色设置不同的访问权限,从而控制数据的访问和操作。
  • 数据加密:支持数据在存储和传输过程中的加密,掩护数据不被非法访问。包括列级加密和透明数据加密等。
  • 审计功能:达梦数据库具备审计功能,可以记录用户的操作举动和系统事件,资助追踪和审计数据访问和修改记录。
  • 防御机制:包括防止SQL注入、恶意攻击等安全防护措施,增长数据库系统的安全性。
  3. 兼容性
   

  • 与标准SQL兼容:达梦数据库支持标准SQL语法,确保与许多现有的SQL应用步伐和工具兼容。
  • 跨平台支持:达梦数据库可以运行在多种操作系统上,包括Windows和Linux。这使得它在不同的环境中都能进行部署和操作。
  • 兼容其他数据库:在迁移或集成过程中,达梦数据库提供了工具和功能以支持与其他数据库(如Oracle、MySQL等)的数据迁移和兼容性处理。
  • 支持多种编程接口:达梦数据库支持多种编程语言和接口,如JDBC、ODBC等,方便与各种应用步伐进行集成。
  
九、总结

也是国内更推行的国产数据库盛行趋势,是国内自主研发的一款RDBMS,其实本质跟oracle使用起来不会有太多的差别,对oracle有相识的自然用起来也会得心应手

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

西河刘卡车医

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表