如何利用SQL语句创建数据库详解

 更新时间:2022年06月16日 15:10:47   作者:有大病么你说  
数据库就是一个文件系统,访问数据的时候需要通过标准的SQL语言来完成,下面这篇文章主要给大家介绍了关于如何利用SQL语句创建数据库的相关资料,需要的朋友可以参考下

前言

SQL语言是集DDL、DML和DCL于一体的数据库语言

SQL语言主要由以下9个单词引导的操作语句来构成,但每一种语句都能表达复杂的操作请求

  • DDL语句引导词:Create(建立),Alter(修改),Drop(撤销)

模式的定义和删除,包括定义Database, Table,View,Index,完整性约束条件等,也包括定义对象(RowType行对象,Type列对象)

  • DML语句引导词:Insert,Delete,Update,Select

各种方式的更新与检索操作,如直接输入记录,从其他Table(由SubQuery建立)输入

各种复杂条件的检索,如直接查找,模糊查找,分组查找,嵌套查找等

各种聚集操作,求平均、求和、……等,分组聚集,分组过滤等

  • DCL语句引导词:Grant,Revoke

安全性控制:授权和撤销授权

建立数据库

包括两件事:定义数据库和表(DDL),向表中添加元组(DML)

DDL:

创建数据库(DB)

create database 数据库名;

创建DB中的Table(定义关系模式)

create table 表名(列名 数据类型 【Primary key| Unique】【Not null】

【,列名 数据类型 【Not null】,...】);

举例:定义学生表

Create Table Student(S# char(8) not null, Sname char(10), Ssex char(2), Sage integer, D# char(2), Sclass char(6));   // S#表示id

"【】"表示其括起的内容可以省略,"|"表示其隔开的两项可取其一

Primary key:主键约束。每个表只能创建一个主键约束。

Unique:唯一性约束(即候选键),可以有多个唯一性约束。

Not null:非空约束。选择Not null表明该列不允许有空值出现。

语法中的数据类型在SQL标准中有定义。

在SQL-92标准中定义的数据类型

  • char(n): 固定长度的字符串
  • varchar(n): 可变长度字符串
  • int: 整数 //有时不同系统也写作integer
  • numeric(p, q): 固定精度数字,小数点左边p位,右边p-q位
  • real: 浮点精度数字 //有时不同系统也写作float(n),小数点后保留n位
  • date: 日期(如2021-09-12)
  • time: 时间(如15:25:00)
  • ...

现行商用DBMS的数据类型有时和上面有些差异,请注意;和高级语言的数据类型总体上是一致的,但也有些差异。

  • 定义Table及其各个属性的约束条件(完整性约束)
  • 定义View(定义外模式及E-C映像)
  • 定义Index、Tablespace……等(定义物理存储参数)
  • 上述各种定义的撤销与修正

DDL通常由DBA来使用,也有DBA授权后由应用程序员来使用

包括两件事:定义数据库和表(DDL),向表中添加元组(DML)

DML:

  1. 向Table中追加新的元组:Insert
  2. 修改Table中某些元组的某些属性的值:Update
  3. 删除Table中的某些元组:Delete
  4. 对Table中的数据进行各种条件的检索:Select

DML通常由用户或应用程序员使用,访问经授权的数据库

向表中追加元组

insert into 表名【(列名)【,列名】…】

        values(值【,值】,…);

示例:追加学生表中的元组

Insert Into Student

Values(‘08042202’,‘张三’,‘男’,20,‘03’,‘080422’);

Insert Into Student(S#,Sname,Ssex,Sage,D#,Sclass)

Values(‘08042202’,‘张三’,‘男’,20,‘03’,‘080422’);

values后面值的排列,须与into子句后面的列名排列一致

若表名后的所有列名省略,则values后的值的排列,须与该表存储中的列名排列一致

总结

到此这篇关于如何利用SQL语句创建数据库的文章就介绍到这了,更多相关SQL语句创建数据库内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 数据库查询排除重复记录的方法

    数据库查询排除重复记录的方法

    这篇文章主要介绍了数据库查询排除重复记录的方法,使用DISTINCT语句实现,需要的朋友可以参考下
    2014-06-06
  • sql2005可实时监测数据库版本控制SQL的触发器

    sql2005可实时监测数据库版本控制SQL的触发器

    用于sql2005实时监测数据库版本控制SQL的触发器
    2008-10-10
  • SQL中Having与Where的区别及注意

    SQL中Having与Where的区别及注意

    这篇文章给大家详细的介绍了SQL中Having与Where的区别,以及这两者的注意事项,文中还分享了Having与Where的示例代码,相信对大家的理解和学习很有帮助,感兴趣的朋友们可以参考借鉴,有需要的朋友们可以一起学习学习。
    2016-11-11
  • windows安装Neo4j图数据库的详细过程

    windows安装Neo4j图数据库的详细过程

    本文介绍了在Windows上安装和配置Neo4j图数据库的步骤,包括安装JavaSDK、解压安装Neo4j、配置环境变量、启动数据库以及服务化启动,感兴趣的朋友一起看看吧
    2025-03-03
  • 关于关系数据库如何快速查询表的记录数详解

    关于关系数据库如何快速查询表的记录数详解

    这篇文章主要给大家介绍了关于关系数据库如何快速查询表的记录数的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用关系数据库具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-04-04
  • 分享三种高效率SQL语句分页方法

    分享三种高效率SQL语句分页方法

    分享三种高效率SQL语句分页方法,需要的朋友可以参考下。
    2011-09-09
  • GaussDB数据库事务管理及高级应用

    GaussDB数据库事务管理及高级应用

    GaussDB是华为公司开发的一种数据库产品,它是一种分布式关系型数据库管理系统(RDBMS),这篇文章主要给大家介绍了关于GaussDB数据库事务管理及高级应用的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-05-05
  • Hive HQL支持2种查询语句风格

    Hive HQL支持2种查询语句风格

    这篇文章主要为大家介绍了Hive HQL支持2种查询语句风格示例语法,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • dataGrip显示clickhouse时间字段不正确的问题

    dataGrip显示clickhouse时间字段不正确的问题

    最近做数据迁移碰到一个问题,源数据和目的端数据,导入的时间怎么都差8个小时,本文就来介绍一下如何解决,感兴趣的可以了解一下
    2021-09-09
  • MySQL与Oracle差异比较之三 函数

    MySQL与Oracle差异比较之三 函数

    这篇文章主要介绍了MySQL与Oracle差异比较之三 函数,需要的朋友可以参考下
    2017-04-04

最新评论