1、规范

  ①关键字与函数名称全部大写;

  ②数据库名称、表名称、字段名称全部小写;

  ③SQL语句必须以分号结尾。

2、数据库操作

// 1. 创建数据库,其中[]表示可以省略

CREATE { DATABASE | SCHEMA } [IF NOT EXISTS] db_name [DEFAULT] CHARACTER SET [=] charset_name;

// 2、 显示当前服务器下的数据库列表

SHOW { DATABASES | SCHEMAS } [LIKE 'pattern' | WHERE expr];

// 3、 修改数据库编码方式

ALTER  { DATABASE | SCHEMA } [IF NOT EXISTS] db_name [DEFAULT] CHARACTER SET [=] charset_name;

// 4、 删除数据库

DROP  { DATABASE | SCHEMA } [IF NOT EXISTS] db_name ;

3、数据类型

  (1)整数: 

 

  (2)浮点型:

  (3)日期型:

  (4)字符型:

4、数据表操作:

  (1)、创建表:

CREATE TABLE [IF NOT EXISTS] table_name(column_name1 data_type , column_name2 data_type , ……);

  (2)、查看当前数据库表列表:

SHOW TABLES [FROM db_name];

  (3)、查看表结构:

SHOW COLUMNS FROM table_name;

  (4)、向数据表中插入数据:

INSERT [INTO]  tb_name  [(col_name1,col_name2,……)]  VALUES(val1,val2,……);

  (5)、查询表数据:

SELECT expr,…… FROM tb_name;

  (6)、查看索引:

SHOW INDEXES FROM table_name \G;

  

 5、约束:

  (1)、非空约束:  NOT NULL;

  (2)、自动编号: AUTO_INCREMENT(必须与主键约束组合使用);

  (3)、主键约束: PRIMARY KEY(保证数据的唯一性,主键自动为NOT NULL,每个数据表只能有一个主键);

  (4)、唯一约束: UNIQUE KEY(可以保证数据的唯一性,卫衣约束的字段可以为空值,每一个数据表可以有多个唯一约束);

  (5)、默认值: DEFAULT.

  (6)、外键约束: FOREIGN KEY(保证数据的一致性、完整性,实现一对一或一对多关系),需要满足以下4个条件:

      ①父表和子表必须使用相同的存储引擎,而且禁止使用临时表;

      ②数据表的存储引擎只能是InnoDB;

      ③外键和参照列必须具有相似的数据类型,其中数字的长度或者是否有符号位必须相同,而字符的长度则可以不同;

      ④外键列和参照列必须创建索引,如果外键列不存在索引的话,MYSQL将自动创建索引。

    外键约束的操作:FOREIGN KEY (col_name) REFERENCES foreign_key_table_name(col_name)  [ON DELETE | UPDATE ]  [CASCADE | SET NULL | RESRTICT | NO ACTION]

    其中,CASCADE表示从父表中删除或更新且自动删除或更新子表中匹配的行,SET NULL表示从父表中删除或更新行并设置子表中的外键列位空(如果使用该选项必须保证子表外键列没有指定NOT NULL),RESTRICT表示拒绝对父表的删除或更新操作,NO ACTION表示无动作(标准的SQL的关键字,在mysql中和RESTRICT相同)。

  表级约束在列定义后声明,列约束前后声明均可

6、数据表创建后的操作:

  (1)、添加单列:

ALTER TABLE table_name ADD [COLUMN] col_name  column_definition [FIRST | AFTER col_name];

  (2)、添加多列:

ALTER TABLE table_name ADD [COLUMN] (col_name column_definition,col_name2 column_definition,……);

  (3)、删除列:

ALTER TABLE table_name DROP [COLUMN]  col_name;

  (4)、删除多列:

ALTER TABLE tabla_name DROP [COLUMN] col_name1,DROP [COLUMN] col_name2,……;

  (5)、添加主键约束([constraint [symbol]]为约束的名字):

ALTER TABLE talbe_name ADD [constraint [symbol]] PRIMARY KEY [index_type](index_col_name,……);

  (6)、添加唯一约束:

ALTER TABLE table_name ADD [constraint [symol]] UNIQUE [INDEXE | KEY] [index_name ] [index_type] (inde_col_name,……);

  (7)、添加外键约束:

ALTER TABLE table_name ADD [COSTRAINT[symbol]] FROEIGN KEY [index_name] (index_col,……);

  (8)、添加、删除默认约束:

ALTER TABLE table_name ALTER [COLUMN] col_name {SET DEFAULT default_val | DROP PRIMARY KEY} ;

  (9)、删除主键约束:

ALTER TABLE table_name DROP PRIMARY KEY;

  (10)、删除唯一约束或索引:

ALTER TABLE table_name DROP {INDEX | KEY} index_name;

  (11)、删除外键约束:

ALTER TABLE table_name DROP FOREIGN KEY fk_symbol;

  (12)、修改列定义:

ALTER TABLE table_name MODIFY [COLUMN] col_name colum_definition [FIRSST | AFTER col_name];

  (13)、修改列名称(可以修改列名称):

ALTER TABLE table_name CHANGE [COLUMN] old_col_name new_col_name column_definition [FIRST AFTER col_name];

   (14)、 数据表更名:

//方法一:

ALTER TABLE table_name RENAME [TO | AS] new_table_name;

//方法二:

RENAME TABLE table_name1 TO new_table_name1 ,[table_name2 TO new_table_name2],……;

  

SQL数据库操作整理的更多相关文章

  1. 个人博客设计:创建Sql数据库操作类。

    整体的博客框架如下 数据库操作java类如下 package com.yxq.dao; import java.sql.Connection; import java.sql.DriverManage ...

  2. HTML5 Web SQL 数据库操作

    Web SQL 数据库 API 并不是 HTML5 规范的一部分,但是它是一个独立的规范,引入了一组使用 SQL 操作客户端数据库的 APIs. 以下是规范中定义的三个核心方法: openDataba ...

  3. SQL数据库操作(CURD)

    对数据仓库的操作(CURD): 新增:  create database db_test; 新增的时候设置编码: create database da_test_1 character set utf ...

  4. Yii1 的数据库操作整理

    1.根据条件查询一个集合 $objectResult=Post::model()->findAll($condition,$params);$objectResult=Post::model() ...

  5. qt sql 数据库操作

    1.  连接数据库 mysql连接: QSqlDatabase mysql_db=QSqlDatabase::addDatabase("QMYSQL","mysql_co ...

  6. C#对SQL数据库操作类简介:Connection、Command、DataReader、DataSet、DataAdapter

    在说C#操作数据库之前需要先说下ADO.NET.ADO.NET的名称起源于ADO(ActiveX Data Objects),是一个COM组件库,用于在以往的Microsoft技术中访问数据.之所以使 ...

  7. sql 数据库操作语句 不带select

    MySQL数据操作语句 1.总纲 DDL -数据定义语句** create/drop/alter ** create: 创建 drop:删除 alter:修改 DML -数据操作语句 ** inser ...

  8. 常见 PL.SQL 数据库操作

    Oracle PL/SQL 1, Alt +E 2, 默认大写功能, 解析SQL原则,Comment,UnComment. 3, 触发Trig,使用Test Window. 4, Compile In ...

  9. SQL数据库操作总结

    1. 如何增加(创建)数据库 语法 CREATE DATABASE database_name 2.如何增加(创建)数据表 语法 CREATE TABLE table_name { column_na ...

随机推荐

  1. Python基础之字符串操作

    字符串的常用操作包括但不限于以下操作: 字符串的替换.删除.截取.复制.连接.比较.查找.分割等 这里将对字符串的内置操作方法进行总结归纳,重点是以示例的方式进行展示. 使用type获取创建对象的类 ...

  2. Unity3D之Mesh(二)为三角形添加纹理

    一.直接開始上步驟 首先繪製一個三角形 創建一個材質,以便後續使用: 1)材質使用的貼圖 2)上代碼 using UnityEngine; using System.Collections; /* = ...

  3. python基础-循环语句while

    循环语句:while\for\嵌套 循环控制语句:break\continue break:跳出整个循环,不会再继续循环下去 continue:跳出本次循环,继续下一次循环 while循环: coun ...

  4. codeforces 707A A. Brain's Photos(水题)

    题目链接: A. Brain's Photos 题意: 问是黑白还是彩色; 思路: 没有思路: AC代码: #include <iostream> #include <cstdio& ...

  5. JAVA堆内存和栈内存初步了解

    一.堆内存和栈内存 程序运行时内存分配有三种:静态存储分配,栈式存储分配,堆式存储分配 1.静态存储分配: 在程序编译时就可以确定数据目标在运行时所需要的内存,因此在编译时就为其分配固定大小的内存. ...

  6. 如何查看myeclipse是否激活

    myEclipse---->Subscription information--->Subscription expiration date 看这个日期到什么时候!另外建议别用太高版本的M ...

  7. c/c++写的比较好的读写配置文件的函数或者类

    共用版  .h文件 //---------------------------------------------------------------------------- // 程序名称:    ...

  8. iOS中的日期和时间

    转载于http://www.jianshu.com/p/ee279c175cf8 一.时间和日期计算 我们在应用开发中,时常需要和时间打交道,比如获取当前时间,获取两个时间点相隔的时间等等,在iOS开 ...

  9. 在屏幕中间显示,按ESC键后改变字符的颜色

    程序功能:编写程序在屏幕中间显示“a”~“z”,并可以让人看清,这个任务比较好实现. (1)在b800:[ 160*12+40*2]处存入a的ASCII码.(2)在循环中使用一个10000000000 ...

  10. Ubuntu下locale文件

    March 7, 2015 11:44 PM locale文件 关于locale文件的设定 locale 是国际化与本土化过程中的一个非常重要的概念,个人认为,对于中文用户来说,通常会涉及到的国际化或 ...