SQL是一个标准的数据库语言,是面向集合的描述性非过程化语言。

  • 优点:功能强、效率高、简单易学易维护。
  • 缺点:非过程化语言,大多数语言都是独立执行,与上下文无关,而大多数 应用都是一个完整的过程,显然用SQL完全实现这些功能是很困难的。

大多数数据库公司从以下两方面来解决此问题:

    1)扩充SQL,在SQL中引入过程性结构

    2)把SQL嵌入到高级语言中

表(TABLE)

视图(VIEW)

索引(INDEX)

同义词(SYN)

聚簇(CLUSTER)

数据库操作:

  创建数据库:create database 库名  例如:create database db1  //创建一个名为db1的数据库

  删除数据库:drop database 库名  例如:create database db1  //删除名为db1的数据库

  查看数据库:show databases  //显示所有库名

  使用数据库:use 库名

  重命名数据库:停止服务 -> 修改数据库所在文件夹的名称 -> 启动服务

数据表操作:

  创建数据表:create table 表名  例如:create table tb1  //创建一个名为tb1的表,例如create table tb1 (id int)

  删除数据表:drop table 表名  例如:drop table tb1  //删除一个名为tb1的表  drop table if exists tb5(若存在则删除)

  重命名数据表:rename table 表1 to 表2

  查看数据表:show tables  //显示当前库中的所有表名

  查看表结构:describe 表名

  修改表结构:

    添加字段:alter table 表名 add 列名 属性   例如:alter table tb1 add id int  //给表tb1中增加一个字段id,属性为int  alter table tb1 add addr varchar(10) after id(在id列后增加addr列)

    删除字段:alter table 表名 drop 列名  例如:alter table tb1 drop id  //删除表tb1中的id字段

    修改字段名称:alter table 表名 change 列名 新列名 属性  例如:alter table tb1 change id  id_new int  //将表tb1的id字段名称改为id_new

    修改字段属性:alter table 表名 change 列名 列名 新属性  例如:alter table  tb1 change id int decimal  //将表tb1的id字段属性int改为decimal

    修改字段属性:alter table 表名 modify 列名 新属性  例如:alter table tb1 modify id decimal

表中数据操作(增删改查):

  插入数据:insert into 表名(列1,列2) values (值01,值02),(值11,值12)

  查询数据:select 列名 from 表名 where 查询条件

  修改数据:update 表名 set  列名=值 where 条件

  删除记录:delete from 表名 where 条件

数据复制:

  创建新表 - 复制旧表结构及数据到新表    create table 新表 select * from 旧表

  创建新表 - 仅复制旧表结构  create table 新表 select * from 旧表 where 1=2

  创建新表 - 新旧表结构不同(新表中仅包含旧表中个别字段)  create table 新表 select 列1,列2 from 旧表

  复制旧表数据到新表(表结构相同)insert  into 新表 select * from 旧表

  复制旧表数据到新表(表结构不同)insert into 新表(列1,列2) select 列1,列2 from 旧表

 
 

 grant赋予权限:

  grant 权限1,权限2,…权限n on 数据库名称.表名称 to 用户名@用户地址 identified by ‘密码’;

  • 权限1,权限2,…权限n代表select,insert,update,delete,create,drop,index,alter,grant,references,reload,shutdown,process,file等14个权限。
  • 当权限1,权限2,…权限n被all privileges或者all代替,表示赋予用户全部权限。
  • 当数据库名称.表名称被*.*代替,表示赋予用户操作服务器上所有数据库所有表的权限。
  • 用户地址可以是localhost,也可以是ip地址、机器名字、域名。也可以用’%'表示从任何地址连接。
  • ‘连接口令’不能为空,否则创建失败。
  • 如果带了 with grant option,那么用户testuser1可以将select ,update权限传递给其他用户( 如testuser2)。如果没带,则不能将权限传递给第三方。

  例如:给所有host下的zy用户,赋予所有数据库和表的一切权限

    mysql> grant all privileges on *.* to zy@'%' identified by '123456' with grant option;  // %表示从任何地址连接

    mysql> flush privileges;  //刷新系统权限表,使以上grant生效

    

(一)SQL -- 基础知识的更多相关文章

  1. [SQL] SQL 基础知识梳理(一)- 数据库与 SQL

    SQL 基础知识梳理(一)- 数据库与 SQL [博主]反骨仔 [原文地址]http://www.cnblogs.com/liqingwen/p/5902856.html 目录 What's 数据库 ...

  2. [SQL] SQL 基础知识梳理(二) - 查询基础

    SQL 基础知识梳理(二) - 查询基础 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5904824.html 序 这是<SQL 基础知识梳理( ...

  3. [SQL] SQL 基础知识梳理(三) - 聚合和排序

    SQL 基础知识梳理(三) - 聚合和排序 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5926689.html 序 这是<SQL 基础知识梳理 ...

  4. [SQL] SQL 基础知识梳理(四) - 数据更新

    SQL 基础知识梳理(四) - 数据更新 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5929786.html 序 这是<SQL 基础知识梳理( ...

  5. [SQL] SQL 基础知识梳理(五) - 复杂查询

    SQL 基础知识梳理(五) - 复杂查询 [博主]反骨仔 [原文]http://www.cnblogs.com/liqingwen/p/5939796.html 序 这是<SQL 基础知识梳理( ...

  6. [SQL] SQL 基础知识梳理(六)- 函数、谓词、CASE 表达式

    SQL 基础知识梳理(六)-  函数.谓词.CASE 表达式 目录 函数 谓词 CASE 表达式 一.函数 1.函数:输入某一值得到相应输出结果的功能,输入值称为“参数”,输出值称为“返回值”. 2. ...

  7. [SQL] SQL 基础知识梳理(七)- 集合运算

    SQL 基础知识梳理(七)- 集合运算 目录 表的加减法 联结(以列为单位) 一.表的加减法 1.集合:记录的集合(表.视图和查询的执行结果). 2.UNION(并集):表的加法 -- DDL:创建表 ...

  8. 常见SQL语句和SQL基础知识

    引自:http://blog.csdn.net/u012467492/article/details/46790205 SQL语句考察(一) 1.查询出每门课都大于80 分的学生姓名 name   k ...

  9. SQL 基础知识终极指南

    什么是数据库? 数据库是以电子方式从系统中存储和检索的大量数据集合. 存储在数据库中的结构化数据被处理.操纵.控制和更新以执行各种操作. 行业中使用的一些流行数据库是 Oracle.MySQL.Pos ...

  10. sql基础知识集锦

    Sql常用语法 下列语句部分是Mssql语句,不可以在access中使用. SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT ...

随机推荐

  1. System.InsufficientMemoryException:无法分配536870912字节的托管内存缓冲区。可用内存量可能不足

    一个病人住院太久,一次性打印护理表单超过3000条时报如标题所示的错误, 个人查阅分析应该可以从如下几方面入手: 一:查看程序客户端和服务端的配置文件相关属性是否限制了缓存最大值 (应该不是这个问题, ...

  2. Ubuntu下Win10虚拟机卡顿问题解决

    问题描述 Ubuntu下用VMware创建了一个Windows10的虚拟机,初始给的配置如下: Memory: 4GB Graphics Memory: 1GB Hard Disk: 60GB 用的时 ...

  3. 虚拟机Vmware-网络配置

    非主业,只做简单介绍 虚拟机安装完毕后,需要进行网络配置. 虚拟机有 3 种网络连接方式: 仅主机模式 Host-only:仅支持 虚拟机与宿主机之间进行通信,无法连接外网 桥接模式 bridge:可 ...

  4. loj 2778「BalticOI 2018」基因工程

    loj luogu 这题和NOI那道向量内积一个套路 首先考虑求两行的不同元素个数,可以转化成一个行向量\(a\)和列向量\(b\)相乘得到一个值.如果只有\(A,C\)两种字符,那么令对应权值\(A ...

  5. CF528E Triangles 3000

    cf luogu 既然要求三角形面积,不如考虑三角形的面积公式.因为是三条直线,所以可以考虑利用三个交点来算面积,如果这个三角形按照逆时针方向有\(ABC\)三点,那么他的面积为\(\frac{\ve ...

  6. redis远程连接配置

    解决redis远程连接不上的问题 redis现在的版本开启redis-server后,redis-cli只能访问到127.0.0.1,因为在配置文件中固定了ip,因此需要修改redis.conf(有的 ...

  7. iphone手机软件安装目录

    iPhone系统常用文件夹位置 1.[/Applications] 常用软件的安装目录 2. [/private /var/ mobile/Media /iphone video Recorder] ...

  8. Java的duotaix

    今天看到博客园上一位原创的博文讲解Java多态性,觉得不错,不过没有解释,特此注释,侵删 public class MyTest { public static void main(String ar ...

  9. Redox OS 发布 0.5 版

    Redox OS 是一个几乎完全以 Rust 语言编写的通用操作系统及周围生态(例如文件系统.显示服务器及 Rust 版本的 libc).其遵循微内核架构,在一定程度上兼容于 POSIX. 该项目于日 ...

  10. Laravel5学习

    [1]缓存问题 laravel中使用的配置文件,都会放在config目录下面,当变更某个参数的时候,如果发现不生效,可以在命令行下面执行  php artisan config:clear 命令才清除 ...