求一个sql写法

如何用SQL开通过上面的数据表生成下面的数据表格呢?
感觉怎么写都不太能搞定。
有数据库大神能指点一下不???

简单的写了一下,可是这个确爆出了奇怪的错误》》

前言: 关系数据库的简单介绍
说明:父查询调用子查询只执行一次.

把绑定字符串和日期类型变量时,变量外面要加单引号
也可绑定变量来查询不同的字段名
输入变量值的时候不要加;等其它符号

4. 实体关系模型例子
每个订单都必须有一个或几个客户
每个客户可能是一个或几个订单的申请者

6. 校正实体关系的原则
属性是单一值的, 不会有重复
属性必须依存于实体, 要有唯一标记
没有非唯一属性依赖于另一个非唯一的属性
7. 定义结构时的注意事项
减少完整性约束产生的问题
确认省略的实体,关系和属性

9. 把实体关系图映射到关系数据库对象的方法
把简单实体映射到数据库里的表
把属性映射到数据库里的表的字段, 标明类型和注释
把唯一标记映射到数据库里的唯一关键字
把实体间的关系映射到数据库里的外键

建立视图,使信息有不同的呈现面, 减少复杂的SQL语句
重新定义完整性约束条件

2. 创建表时给字段加默认值 和约束条件
创建表时可以给字段加上默认值
这样每次插入和修改时, 不用程序操作这个字段都能得到动作的时间

4. 创建表时的命名规则和注意事项
表名和字段名的命名规则:必须以字母开头,可以含符号A-Z,a-z,0-9,_,$,#
不用SQL里的保留字, 一定要用时可用双引号把字符串括起来.
用和实体或属性相关的英文符号长度有一定的限制

建表时可以用中文的字段名, 但最好还是用英文的字段名
创建表时要把较小的不为空的字段放在前面, 可能为空的字段放在后面
建表时如果有唯一关键字或者唯一的约束条件,建表时自动建了索引
一个表的最多字段个数也是有限制的,254个.

5. 约束名的命名规则和语法
约束名的命名规则约束名如果在建表的时候没有指明,系统命名规则是SYS_Cn(n是数字)
约束名字符串的命名规则同于表和字段名的命名规则

6. 使用约束时的注意事项
约束里不能用系统函数,如SYSDATE和别的表的字段比较
可以用本表内字段的比较

10. 用子查询建表的注意事项
可以关连多个表及用集合函数生成新表,注意选择出来的字段必须有合法的字段名称,且不能重复。
用子查询方式建立的表,只有非空NOT NULL的约束条件能继承过来, 其它的约束条件和默认值都没有继承过来.

12. 如果数据库表里有不满足的记录存在,建立约束条件将不会成功.

十、ORACLE里的数据字典
1. 什么是数据字典ORACLE的数据字典是数据库的重要组成部分之一,它随着数据库
 的产生而产生, 随着数据库的变化而变化, 体现为sys用户下所有的一些表和视图.

2. 数据字典里存了以下内容:用户信息
 用户的权限信息
 所有数据对象信息表的约束条件统计分析数据库的视图等
 不能手工修改数据字典里的信息.

2. 插入字符串类型的字段的注意事项:
字符串类型的字段值必须用单引号括起来, 例如: ’GOOD DAY’
如果字段值里包含单引号’ 需要进行字符串转换, 我们把它替换成两个   单引号’ ’
字符串类型的字段值超过定义的长度会出错, 最好在插入前进行长度校验
日期字段的字段值可以用当前数据库的系统时间SYSDATE, 精确到秒
INSERT时最大可操作的字符串长度小于等于4000个单字节,
如果要插入更长的字符串, 请考虑字段用CLOB类型, 方法借用ORACLE里自带的DBMS_LOB程序包.

7. DML操作的注意事项
以上SQL语句对表都加上了行级锁, 确认完成后, 必须加上事物处理结束的命令COMMIT 才能正式生效,
否则改变不一定写入数据库里.行级锁也未能得到释放.
如果想撤回这些操作, 可以用命令 ROLLBACK 复原.
应该把它限定在较小 (一万条记录) 范围内,. 否则ORACLE处理这个事物用到很大的回退段.
程序响应慢甚至失去响应. 如果记录数上十万以上这些操作,
可以把这些SQL语句分段分次完成, 其间加上COMMIT 确认事物处理.
太过频繁的commit不好

2. 删除表及表里的数据
按时间清空日志表里的记录,使用重新命名的方法(应用程序可能有短暂出错, 可以选择在不繁忙的时间执行)
按原来表A的建表语句创建新表A1,
把表A重命名为A2(如果表A上有较频繁的DML操作,会对表加上行级锁,重命名过程用递归的方式循环做,直到DML操作结束,命名成功).
把创建新表A1重命名为A
历史记录表A2备份或删除

3.  删除表后应该注意的问题
删除表后把表里的索引一起删去.
删除表后会结束基于它的悬而未决的事物

序列号的名称一般可以采用“表名_字段名”的命名规则

1. 视图的概念和优点
视图是基于一个或多个表及视图的一些查询语句, 它象显示数据的视窗, 它本身是不存储数据的.
视图可以限制数据库的访问, 更好的控制权限
使用户使用简单的查询语句
同一数据的不同表现形式

索引是数据库里的一种数据对象
它和表是分开存放的两个实体
索引创建好了后, 由系统自动调用和管理

2. 什么时候创建索引?
自动创建的索引:唯一关键字, 唯一的约束条件
手工需要创建的索引:大表查询时, sql语句where后经常用到的字段或字段组合
  字段内容差别很大有大量NULL值表很大, 返回记录数较少

3. B*树索引的结构 每个索引由字段值和指针或ROWID组成

5.创建索引的注意事项
 创建索引时会加行级独占锁
 一个表的索引最好不要超过三个 (特殊的大表除外)
 最好用单字段索引
 索引最好和表分不同的表空间存放
 结合SQL语句的分析执行情况, 也可以建立多字段的组合索引和基于函数的索引
 大表的索引会占用很大的存储空间
 不要建唯一的索引, 而应该加唯一的约束条件

注意: 数据字典里存放的字符都是大写的.

where后不经常使用的比较字段

角色是命名多个相关权限的组合. 能把它赋于其它的用户或角色我们能创建角色, 使权限管理更容易一些.

注意: 如果用WITH ADMIN OPTION通过中间用户赋于的系统权限 中间用户删除后, 系统权限仍然存在.

9、赋于数据对象级的权限语法和例子

  • 解决基本crud代码重复的问题
  1. 提供强大的CRUD操作
  2. 支持自定义全局通用操作
  3. 内置分页插件,分页插件支持多种数据库
  1. 内置代码生成器,分页插件,性能分析插件等(只是mybatis分页等需要依赖第三方插件)
  2. 提高功能丰富的条件构造器快速进行无sql开发(只是mybatis需要提供大量的xml文件)
  1. 继承的接口中,定义了一些常用的crud的方法,所以我们可以使用里面的方法
  2. 我们的接口定义的时候需要明确指定操作实体对象.mp底层通过反射解析该实体对象,获取实体对象类名,字段,作为拼接sql语句的表名和字段名,然后根据crud操作,拼接处对应的crud sql语句.所以:我们的的实体类名和表名,必须和数据库的表名和列名一致
  3. 接口中有一个泛型,泛型是当前mapper要操作的实体类
  • 表名注解(贴在实体类的对象名字上面),指定映射数据库中的哪一个表名
  • 一般使用在数据库中的名字比较特殊(t_xxx等)
  • 字段注解(不适用在主键上,贴在你要注解的字段上),指定当前属性映射数据库中的哪一列
  • 主键注解(贴在主键上),标记当前属性映射表主键。
  • 第一种日志带有时间,操作人,执行的方法,sql语句等
  • 第二种日志只有sql语句
  • 使用在全量更新,只要传入对象属性不为bull,都可以进行update更新,条件通过id匹配
    在执行过程中,会将属性为null的字段忽略,不为null的字段拼接到updateById sql语句中
  1. 建议将基本类型使用包装类型进行操作
  • 部分字段更新,通过wrapper对象拼接各种满足要求条件, 更新set的列由wrapper决定

5.3.3 两种方式的区别

  • 参数1: 通过对象方式指定要更新的列与数据
  • 如果指定了对象,mp会对这个对象里面所有非null的属性,拼接到set语法中
  • 通过id删除对应的信息
  • 根据List存放的多个id,删除多个id
  • 通过多个条件删除符合条件的信息
  1. 往map集合里面存放条件注意: 必须加条件,不然会清空表数据
  • 根据map里面的条件进行查询
  • 统计符合条件的信息有多少条
  • 查询满足条件的所有信息, 返回List 对象
  1. 配置一个分页的插件(拦截器)(在启动类中)
 
  1. 创建出来的对象用接口接收
  2. 参数1:当前页 参数2:每页显示条数
  • 查询全部记录,无指定返回第一列的数据(id).指定返回指定的列的数据
  • 分页后返回的结果是HashMap
  • 定义:条件拼接对象,用于sql中的where条件
  • 在编译阶段就判断字段是否存在,不存在的字段直接报错
  • 查询信息,返回部分的字段

我要回帖

更多关于 sql语句在哪里写 的文章

 

随机推荐