建立主键有两种方法:一种是在数据库提供的GUI环境中建立,另一种是通过SQL语句执行建立,下面分别介绍。
成都创新互联是专业的福贡网站建设公司,福贡接单;提供成都网站设计、成都做网站,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行福贡网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!
1.在数据库提供的GUI环境中建立(以SQL7为例)。
输入表信息后按Ctrl键同时选中多行,然后点上面的主键按钮就行了。
2.通过SQL语句执行建立。又分两种,一是在建表语句中直接写,二是建表之后更改表结构。
在建表语句中直接写:
Create Table 表名 (字段名1 Int Not Null,
字段名2 nvarchar(13) Not Null Primary Key (字段名1, 字段名2),
字段名3字段名N )建表之后更改表结构:
CREATE TABLE 表名 (字段名1 Int Not Null,
字段名2 nvarchar(13) Not Null字段名3字段名N)GOALTER TABLE 表名 WITH NOCHECK ADD
CONSTRAINT [PK_表名] PRIMARY KEY NONCLUSTERED([字段名1],
案例
动态语言注解
import ;
/*
* (1)动态语言注解
对于创建动态的查的语言。MyBatis提供了多个注解如:
@InsertProvider,
@UpdateProvider,
@DeleteProvider和
@SelectProvider,
这些都是建立动态语言和让MyBatis执行这些语言。
(2)@Provider使用思路
对于MyBatis提供的几个@Provider,
里面最主要的参数是type,
也就是sql类的Calss对象,
另外就是对应的方法名,
我们看SelectProvider的源代码:
@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface SelectProvider {
Class? type();
String method();
}
所以要实现动态的SQL查询,那么大体的思路就是,编写一个SqlProvider,比如:DemoSqlProvider,在此方法中返回一条SQL语句即可。然后在Mapper类中使用@SelectProvider注解,指定provider类和对应的SQL方法。
问题:有一个表中有id,name,email等字段,有这么一个查询要求:我们希望的是如果name不为null的话,那么就当做条件,否则就不要当做条件;如果email不为null,那么就当做条件,否则不当做条件。
接下里看看怎么使用@SelectProvider破。
Provider:供应者
*/
public class UserSqlProvider {
/**
* 查询语句.
*/
public String select1(User user ){
StringBuffer sql = new StringBuffer("select * from tb_user1 where 1=1 ");
if(user.getAge() != 0){
sql.append(" and age=#{age}");
}
if(user.getUsername() != null){
if("张三----".contains(user.getUsername())){
sql.append(" and username=#{username}");
}
}
return sql.toString();
}
}
UserMapper
@SelectProvider(type=UserSqlProvider.class,method="select1")
ListUser getUserByIdAndUsername(User user);
不管你是否喜欢,数据都是任何一个应用程序中不可缺少的一部分,尤其是哪些面向对象的应用程序。JAVA程序员在处理数据持久层的时候,比较传统的方式是 写一些复杂的SQL查询语句,但是随着应用程序规模的不断增长,这些内容会使得程序变得难以管理。如果能够用面向对象的方式来处理这些查询,充分运用“封 装”、“抽象”、“继承”和“多态”等特性,这将是多么美妙的一件事情啊。
事实上,JAVA社区已经开发出很多种面向对象的方式来处理数据持久化:EJB,JDO,Hibernate还有Toplink都是非常不错的解决这一问题的方案。而JPA , 则是java EE 5规定的标准的持久化应用程序接口。JPA规范一开始是作为JSR 220:EJB 3.0规范的一部分,目的是简化EJB中实体bean编程模型。尽管它和Java EE 5.0中的实体bean相关,但是在容器之外,在java SE环境中,JPA也是可以使用的。
在这篇文章中,你将会看到,借助于JPA 中的标注,使用面向对象的方式处理数据持久化,是多么的简洁和优雅。这篇文章面向的读者是那些JPA的初学者,同时需要掌握一些基本的关系型数据库 概念以及熟悉JAVA 5中的标注。JPA需要JAVA 5或者更高版本,因为它大量使用了JAVA中的新特性,比如标注和泛型。
OpenJPA 以及样例程序
在这篇文章中,我们将使用OpenJPA 来 进行演示,它是由Apache组织提供的一个JPA规范的具体实现。我之所以选择OpenJPA而不是其他供应商的产品,主要是因为它被集成在 Weblogic、WebSphere和Geronimo等应用服务器当中。在我撰写本文的时候,OpenJPA的最新版本是1.0.1,可以通过Resources section 这个链接来下载。如果你想使用其他的JPA实现,那么很明显你首先要读一读相关文档。
在本文余下的部分当中,我将通过一个例子向您介绍JPA 中的各种概念。这个例子是基于一个名叫XYZ的超市,既有网上店铺也有实体零售店。一开始,你将了解到如何使用JPA对客户模型进行CRUD操作。在后面的部分,你将了解到如何通过对象继承的方式来扩展CRUD操作。
本文代码包 包含了实体监听器以及文章中讨论的三种继承类型(单表、连接、每个类一个表)的代码。
JPA : 如何使用?
为了实现一个JPA 兼容的程序,你需要如下三样东西:
一个实体类
一个 persistence.xml 文件
一个功能类,用于完成插入、更新或者查找一个实体
JPA 只能用于处理数据持久化,下面让我们来看看如何通过JPA来设计数据的存储方式。假设你已经有一个 CUSTOMER 表, 如表1 所示
即使数据库表中的抄记录为空,jpa查询的结果也不是null,而是一个List列表对象数为空百的列表。
你之所以查询结果为空,是因为使用hibernate(如果你是用hibernate作为jpa的实现框架的话)创建的service对象没有创建的缘故。为什么没有创建,请粘贴度源代码分析一下。
很简单的道理,你的service这个对象没有初始化,或者叫没有创建。因为知没有创建这个对象,所以也就没法调用find()这个方法,所以会抛出空指针异常,之所以model==null可以道,是因为server.find()当对象没有创建的的时候就是空null,所以可以。
你的任务是,初始化service这个对象。
MyBatis详解 与配置MyBatis+Spring+MySqlMyBatis 是一个可以自定义SQL、存储过程和高级映射的持久层框架。MyBatis 摒除了大部分的JDBC代码、手工设置参数和结果集重获。MyBatis 只使用简单的XML 和注解来配置和映射基本数据类型、Map 接口和POJO 到数据库记录。相对Hibernate和Apache OJB等“一站式”ORM解决方案而言,Mybatis 是一种“半自动化”的ORM实现。需要使用的Jar包:mybatis-3.0.2.jar(mybatis核心包)。mybatis-spring-1.0.0.jar(与Spring结合包)。MyBatis简介 MyBatis 是一个可以自定义SQL、存储过程和高级映射的持久层框架。MyBatis 摒除了大部分的JDBC代码、手工设置参数和结果集重获。MyBatis 只使用简单的XML 和注解来配置和映射基本数据类型、Map 接口和POJO 到数据库记录。相对Hibernate和Apache OJB等“一站式”ORM解决方案而言,Mybatis 是一种“半自动化”的ORM实现。需要使用的Jar包:mybatis-3.0.2.jar(mybatis核心包)。mybatis-spring-1.0.0.jar(与Spring结合包)。
JPA的那些个注解或XML配置主要是针对ORM的,MyBatis严格来说不算ORM, 它是把SQL映射成Object,不是把数据库表及其关系映射成Object,所以很难用JPA来进行标注。