一、数据库的基本概念

1.1  常用的关系型数据库

                       数据库(Database)是按照数据结构来组织、存储和管理数据的仓库。

1.2  sql语言

     SQL是Structured Query Language(结构化查询语言)的缩写。SQL是专为数据库而建立的操作命令集。SQL功能强大、简单易学、使用方便,已经成为了数据库操作的基础,并且现在几乎所有的关系型数据库均支持SQL。
 
特点
     非过程性语言。一条语句一个结果。多条语句之间没有影响。每一条SQL执行完都会有一个具体的结果出现。
 
SQL是用来操作关系数据库的语言,具有查询、操纵、定义和控制关系型数据库的四方面功能
 

1.3  sql分类

DDL (数据定义语言)
数据定义语言 - Data Definition Language
用来定义数据库的对象,如数据表、视图、索引等
create drop alter truncate
 
DML (数据操纵语言)
数据处理语言 - Data Manipulation Language
在数据库表中更新,增加和删除记录
如 update, insert, delete 不包含查询
 
DCL (数据控制语言)
数据控制语言 – Data Control Language
指用于设置用户权限和控制事务语句
如grant,revoke,if…else,while,begin transaction
 
DQL (数据查询语言)(★★★★★)
数据查询语言 – Data Query Language
数据表记录的查询。
select

二、对数据库进行操作的语句

 
1.1 数据库中默认自带有4个库:
        1.information_schema 数据库:
    其中保存着关于MySQL服务器所维护的所有其他数据库的信息。如数据库名,数据库的表,表栏的数据的表,表栏的数据类型与访问权限等。
        2.performance_schema 数据库:
存储引擎:命名PERFORMANCE_SCHEMA,主要用于手机数据库服务器性能参数。
        3.mysql 数据库:
        mysql库是系统库,里面保存有账户信息,权限信息,存储过程,event,时区等信息
        4.test 数据库:
这个是安装时候创建的一个测试数据库,和它的名字一样,是一个完全的空数据库,没有任何表,可以删除。
 
1.2 查看所有数据库
1.1 查询当前所有的数据库
show databases;
1.2 查看当前数据的创建方式:查看数据库的编码表
show create database 库名;
1.3 创建数据库
create database 数据库名: 由于创建数据库时没有指定编码表,因此会使用安装数据库时默认的编码表
create database 数据库名 character set 编码表名;创建数据库会使用指定的编码表
1.4 删除数据库
drop database 数据库名;
1.5 修改数据库编码集
alter database 数据库名称 character set 字符集;
 
1.3 数据表结构的sql语句
        1.1 数据表的创建语句
        create table 表名(         
 列名 数据类型,          
 列名 数据类型,
 ……
 列名 数据类型 (最后一个列不需要逗号)
        );
1.2 查看表
       show tables : 查看该数据库的所有的表
                show create table 表名 :查看建表语句以及字符集
                desc emp 查看表的详细信息
                show columns from emp ;查看表的列信息
1.4 约束
        1.1 主键约束
                primary key
                varchar 类型的主键不可以自增长.
                示例:
                        【示例】
create table 表名 (
 id int primary key auto_increment,
 name varchar(20),
 ………….
);
          1.2 唯一约束
                unique 内容不允许重复,可以为null(null不算重复)。 
一个表里可以添加多个唯一约束。
【示例】
create table 表名 (
 id int primary key auto_increment,
 name varchar(20) unique,
 ………….
);
唯一约束和主键约束的区别  
1、唯一约束可以是空(null)。 但是主键约束不能为空
2、一张表中只能有一个主键,但是唯一约束可以有多个
          1.3 非空约束
        not null 不允许为空 表示该列的内容 不允许为空。
约束的目的。
目的:保证数据的正确性。
约束列。限制列的内容。
1.5  数据表结构的修改
        1.修改数据表
                可以对表名、表中的列名、列的类型、列的约束进行增删改
                语法 :alter table 表名  add/drop/modify  改名  类型长度  约束;
         2. 修改现有列的类型,长度和约束 用modify
        3. 修改现有列名称
                    语法 alter table 表名 change 旧列名 新列名 类型(长度) 约束;
·        4. 删除现有列
                    语法 alter table 表名 drop 列名;
          5. 修改表名 
                    语法 :rename table 旧表名 to 新表名
          6. 修改表的字符集 
                    语法 : alter table 表名 character set 编码集;
1.6 数据表的删除
         语法 : drop table 表名:
 

三、数据记录的增删改

    
       在java代码中对数据库操作最频繁的就是对表中数据的CRUD操作:create read / retrive update delete
数据记录存储位置
            
                    增:  语法:insert into 表名 (列名,列名,列名。。。) values( 值,值,值。。。);
                    改:update 表名 set 列名 = 值 , 列名 = 值 .. . [where 条件语句];            notes:如果不加条件 则修改整列
                    删:delete :delete from 表名 [where 条件语句]                       
                             notes:如果没有where 删除表中所有的记录    delete 删除的是行
                                          truncate table 表名 是删除一个表,之后在根据你 的表结构在给你创建一张新表
 
 
 
 
 
 

<wiz_tmp_tag id="wiz-table-range-border" contenteditable="false" style="display: none;">

 
 
 
 

16mysql1的更多相关文章

随机推荐

  1. 【Codeforces 115D】Unambiguous Arithmetic Expression

    Codeforces 115 D 题意:给一个没有括号的表达式,问有多少种添加括号的方法使得这是一个合法的表达式?输入可能有正负号.加减乘除.数字. 思路1: 这是不能过的\(naive\)的\(dp ...

  2. C语言程序设计II—第二周教学

    第二周教学总结(4/3-10/3) 教学内容 根据邹欣老师的建议,临时修改教学计划,将最后一周的内容:第十二章 文件,提前讲授. 课前准备 在博客园发布作业:2019春第二周作业 作业根据本周讲授的& ...

  3. MVC 5限制所有HTTP请求必须是POST方式

    今天有位同事,提出了这样一个问题,他想限制所有MVC接收到的HTTP请求必须是POST方式. 接下来在下面的内容中,将我想到的方式分享给大家,如果大家有其它的方式,请留言. 一.HttpPostAtt ...

  4. SQL中char、varchar、nvarchar、ntext的区别(转载)

    char    char是定长的,也就是当你输入的字符小于你指定的数目时,char(8),你输入的字符小于8时,它会再后面补空值.当你输入的字符大于指定的数时,它会截取超出的字符.nvarchar(n ...

  5. AutoMapper自动映射

    十年河东,十年河西,莫欺少年穷. 学无止境,精益求精. 不扯犊子,直接进入正题: AutoMapper自动映射常用于EF中,能很好的解决DTO和Model之间相互映射的问题.在未使用AutoMappe ...

  6. React + js-xlsx构建Excel文件上传预览功能

    首先要准备react开发环境以及js-xlsx插件 1. 此处省略安装react安装步骤 2.下载js-xlsx插件 yarn add xlsx 或者 npm install xlsx 在项目中引入 ...

  7. linux 与 windows 挖门罗币总结

    比特币之前一直很火,初次了解的时候才2000RMB一枚..看不懂哇,错失良机...当然了,看得懂也不买不起..当时还是穷学生. 最近又一直看到黑客利用linux漏洞挖门罗币获利的新闻,决定好生研究一下 ...

  8. nginx域名访问的白名单配置梳理

    在日常运维工作中,会碰到这样的需求:设置网站访问只对某些ip开放,其他ip的客户端都不能访问.可以通过下面四种方法来达到这种效果:1)针对nginx域名配置所启用的端口(比如80端口)在iptable ...

  9. python基础学习笔记(六)

    学到这里已经很不耐烦了,前面的数据结构什么的看起来都挺好,但还是没法用它们做什么实际的事. 基本语句的更多用法 使用逗号输出 >>> print 'age:',25 age: 25 ...

  10. ubuntu——caffe配置deeplab

    1. 下载deeplab 2. 安装matio sudo apt-get install libmatio-dev 3. 修改Makefile文件 LIBRARIES += glog gflags p ...