数据库类型:

  • 层次数据库(Hierarchical Database, HDB)

    数据通过层次结构(树形结构)的方式表示出来。

  • 关系型数据库(Relational Database, RDB)

    使用专门的SQL(Structured Query Language,结构化查询语言)语言对数据信息操作。

  • 面向对象数据库(Object Oriented Database, OODB)

    把数据以及数据的操作集合起来以对象为单位进行管理。

  • XML数据库(XML Database, XMLDB)

    可以对XML形式的大量数据进行高速处理。

  • 键值存储系统(key-Value Store, KVS) 如redis

    单纯用来保存查询所使用的主键和值得组合的数据库。

SQL语句及种类

  • DDL (Data Definition  Language)数据定义语言:

    CREATE : 创建数据库和表对象

    DROP:   删除数据库和表对象

    ALTER:  修改数据库和表对象得结构

  • DML(Data Manipulation Language数据库操作语言)占90%

    SELECT

    INSERT

    UPDATE

    DELETE

  • DCL(Data Control Language数据库控制语言)

    COMMIT:确认对数据库中的数据进行的变更。

    ROLLBACK:取消对数据库中的数据进行的变更。

    GRANT:赋予用户操作权限。

    REVOKE:取消用户的操作权限。

SQL基本书写规则

  SQL语句以分号(;)结尾。

  SQL不区分关键字的大小写。

  书写规则:

    1. 关键字大写
    2. 表名的首个字大写
    3. 其余(列名等)小写

字符串和日期常数需要使用单引号(') 括起来。数字常数无需加注单引号(直接书写数字即可)。

单词之间需要使用半角空格或者换行进行分隔。

表的创建

数据库的创建:CREATE DATABASE <数据库名称>;

表的创建:

CREATE TABLE<表名>

(<列名1>  <数据类型>  <该列所需约束>,

<列名2>  <数据类型>  <该列所需约束>,

...

<该表的约束1>,<该表的约束1>,...)

CREATE TABLE Shohin
(shohin_id CHAR(4) NOT NULL,
shohin_mei VARCHAR(100) NOT NULL,
shohin_bunrui VARCHAR(32) NOT NULL,
hanbai_tanka INTEGER ,
shiire_tanka INTEGER ,
torokubi DATE ,
PRIMARY KEY (shohin_id));

数据库名称、表名和列名等可以使用以下三种字符:半角英文字母、半角数字、下划线(_)。

名称必须以半角英文字母作为开头。

数据类型的指定:INTEGER、CHAR(定长字符串)、VARCHAR(可变长字符串)、DATE

约束:NOT NULL、 NULL、 PRIMARY KEY。

表的删除和更新

删除表:DROP TABLE <表名>;

添加列:ALTER TABLE  <表名>  ADD COLUMN  <列的定义>;

删除列:ALTER TABLE  <表名>  DROP COLUMN  <列名>;

插入数据:

START TRANSACTION;

INSERT INTO Shohin VALUES ('', 'T恤' ,'衣服', 1000, 500, '2009-09-20');
INSERT INTO Shohin VALUES ('', '打孔器', '办公用品', 500, 320, '2009-09-11');
INSERT INTO Shohin VALUES ('', '运动T恤', '衣服', 4000, 2800, NULL);
INSERT INTO Shohin VALUES ('', '菜刀', '厨房用具', 3000, 2800, '2009-09-20');
INSERT INTO Shohin VALUES ('', '高压锅', '厨房用具', 6800, 5000, '2009-01-15');
INSERT INTO Shohin VALUES ('', '叉子', '厨房用具', 500, NULL, '2009-09-20');
INSERT INTO Shohin VALUES ('', '擦菜板', '厨房用具', 880, 790, '2008-04-28');
INSERT INTO Shohin VALUES ('', '圆珠笔', '办公用品', 100, NULL, '2009-11-11'); COMMIT;

SQL---Chapter01 数据库和SQL的更多相关文章

  1. MS SQL Server 数据库分离-SQL语句

    前言 今天在在清理数据库,是MS SQL Server,其中用到分离数据库文件.在这过程中,出现了一个小小的问题:误将数据库日志文件删除了,然后数据就打不开了,除了脱机,其他操作都报错. 数据库分离 ...

  2. SQL SERVER 数据库实用SQL语句

    --查看指定表的外键约束 select * from sysobjects where parent_obj in( select id from sysobjects where name='表名' ...

  3. SQL Server数据库(SQL Sever语言 函数以及SQL编程)

    1.数学函数:操作一个数据,返回一个结果 --去上限: ceiling ☆select ceiling(price) from car --去下限:floor ☆select floor(price) ...

  4. SQL Server数据库(SQL Sever语言 CRUD)

    使用SQL Sever语言进行数据库的操作 常用关键字identity 自增长primary key 主键unique 唯一键not null 非空references 外键(引用) 在使用查询操作数 ...

  5. SQL Server数据库同步SQL

    select table_name,COLUMN_NAME,data_TYPE,CHARACTER_OCTET_LENGTH,CHARACTER_MAXIMUM_LENGTH from informa ...

  6. 从SQL Server数据库导出SQL语句

    不同于直接 备份/恢复 或者 导入/导出 数据库操作. 新版本SQL Server客户端中还可以生成相对应的SQL语句. 非常方便与查看和与其他人共享. 连接上数据库后, 右击数据库, 选择 Gene ...

  7. SQL Server数据库(SQL Sever语言 事务)

    事务:保障流程的完整执行保证程序某些程序在运行时同时成功同时失败,保证程序的安全性 begin tran --在流程开始的位置加 --此处写SQL语句 if @@error>0 --ERRORS ...

  8. SQL Server数据库(SQL Sever语言 存储过程及触发器)

    存储过程:就像函数一样的会保存在数据库中-->可编程性-->存储过程 创建存储过程: 保存在数据库表,可编程性,存储过程create proc jiafa --需要的参数@a int,@b ...

  9. 第一章、关于SQL Server数据库的备份和还原(sp_addumpdevice、backup、Restore)

    在sql server数据库中,备份和还原都只能在服务器上进行,备份的数据文件在服务器上,还原的数据文件也只能在服务器上,当在非服务器的机器上启动sql server客户端的时候,也可以通过该客户端来 ...

  10. SQL Server数据库的备份和还

    转:http://blog.csdn.net/zwj7612356/article/details/8188025 在sql server数据库中,备份和还原都只能在服务器上进行,备份的数据文件在服务 ...

随机推荐

  1. wxPython入门练习代码 三

    DoubleEventFrame.py: #!/usr/bin/env/ python import wx class DoubleEventFrame(wx.Frame): def __init__ ...

  2. RSA大会播报 – 2014最佳安全博客提名(国外篇)

    最佳企业安全博客提名:     Juniper(网络厂商,不用多介绍):http://forums.juniper.net/t5/Security-Mobility-Now/bg-p/networki ...

  3. js 二维码生成 插件

    <div onclick="liaotian()">点击生成二维码</div><div id="qrcode"></d ...

  4. flume从kafka中读取数据

    a1.sources = r1 a1.sinks = k1 a1.channels = c1 #使用内置kafka source a1.sources.r1.type = org.apache.flu ...

  5. 如何使用.NET开发全版本支持的Outlook插件产品(一)——准备工作

    这半年一直在做Outlook的插件,因为不会VC++,所以想找一款基于.NET,用C#开发Outlook插件的技术方案.没想到,光技术选型这件事,就用各种技术手段验证了将近一个月,还花费了大量的精力做 ...

  6. tesseract 编译与使用(windows)

    tesseract是google的一个开源OCR项目,项目地址已经迁移到github(现在 2016/09),地址 https://github.com/tesseract-ocr/tesseract ...

  7. Cordova+ionic 开发hybird App --- 开发环境搭建

    Cordova 开发hybird App 开发环境搭建 一.一些基础概念: Ant : 简单说来可以这么理解,如果你用记事本写JAVA程序,然后在cmd里输入javac命令编译它,但是有一天你发现每次 ...

  8. 利用QJSON将FDQuery转成JSON串

    服务器要支持Http协议,打算采用Http+JSON的方式来交换数据.一开始考虑使用superobject,因为以前使用比较多,比较熟悉. 代码如下: class function FDQueryTo ...

  9. Linux/Unix 线程同步技术之互斥量(1)

    众所周知,互斥量(mutex)是同步线程对共享资源访问的技术,用来防止下面这种情况:线程A试图访问某个共享资源时,线程B正在对其进行修改,从而造成资源状态不一致.与之相关的一个术语临界区(critic ...

  10. little tips of painter.drawRect in Qt

    一个QImage或QPixmap新建变量时,第一次填充图片时设置的宽高正常(fill),其后的绘制操作(draw)则会在绘制的矩形底边和右边加上painter.pen().width() 在下面代码1 ...