是通過映射文件來映射的。舉個簡單的例子,例如我有個Teacher實體類(某教學管理系統老師用戶):
private Integer id; //編號
private String name; //姓名
private String password; //密碼
private Date createDate; //創建日期
同時,我創建了數據表TEACHER:
create table teacher( id number(9) primary key, --編號 name varchar2(20), --姓名 password varchar2(20), --密碼 create_date date --創建日期 );
這時,怎麼關聯它們呢?通過載入hibernate框架,我們就可以使用映射文件來關聯實體類和資料庫了
文件名:Teacher.hbm.xml(必須與實體類名字一致)
內容:
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" " http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Mapping file autogenerated by MyEclipse Persistence Tools-->
<hibernate-mapping>
<class name="com.yss.Teacher" table="TEACHER" schema="WZM">
<id name="id" type="java.lang.Integer">
<column name="ID" precision="9" />
</id>
<property name="name" type="java.lang.String">
<column name="NAME" length="20" />
</property>
<property name="password" type="java.lang.String">
<column name="PASSWORD" length="20" />
</property>
<property name="createDate" type="java.util.Date">
<column name="CREATE_DATE" length="7" />
</property>
</class>
</hibernate-mapping>
當然,這只是比較簡單的映射,還有什麼多對多,一對多等映射,並且映射時如何設置以達到需要的效果,這些你可以在網上搜索相關資料自行查看。
B. 各位大神,請問SQL用戶映射是什麼
指定某個用戶對選定的資料庫分配許可權
用戶映射
public 維護所有默認許可權
db_owner 執行所有資料庫角色活動
db_accessadmin 添加和刪除資料庫用戶, 組及角色
db_ddladmin 添加、更改或刪除資料庫對象
db_security admin 分配語句執行和對象許可權
db_backupoperator 備份資料庫
db_datareader 讀取任何錶中的數據
db_datawriter 添加、更改或刪除所有表中的數據
db_denydatareader 不能讀取任何錶中的數據
db_denydatawriter 不能更改任何錶中的數據
C. 如何編寫Java的MyBatis框架中SQL語句映射部分
1..增刪改查、參數、緩存
1.1 select 舉例如下:
查詢學員信息,一個String參數,參數標識為#{studentID},並返回一個StudentEntity類型的對象
<select id="getStudent" parameterType="String" resultMap="studentResultMap">
SELECT ST.STUDENT_ID,
ST.STUDENT_NAME,
ST.STUDENT_SEX,
ST.STUDENT_BIRTHDAY,
ST.CLASS_ID
FROM STUDENT_TBL ST
WHERE ST.STUDENT_ID = #{studentID}
</select>
1.2 insert 舉例如下:
插入數據,一個String參數,參數標識為#{studentID},並返回一個StudentEntity類型的對象。
<insert id="insertStudent" parameterType="StudentEntity">
INSERT INTO STUDENT_TBL (STUDENT_ID,
STUDENT_NAME,
STUDENT_SEX,
STUDENT_BIRTHDAY,
CLASS_ID)
VALUES (#{studentID},
#{studentName},
#{studentSex},
#{studentBirthday},
#{classEntity.classID})
</insert>
1.3 update 舉例如下:
更新學員信息
<update id="updateStudent" parameterType="StudentEntity">
UPDATE STUDENT_TBL
SET STUDENT_TBL.STUDENT_NAME = #{studentName},
STUDENT_TBL.STUDENT_SEX = #{studentSex},
STUDENT_TBL.STUDENT_BIRTHDAY = #{studentBirthday},
STUDENT_TBL.CLASS_ID = #{classEntity.classID}
WHERE STUDENT_TBL.STUDENT_ID = #{studentID};
</update>
1.4 delete 舉例如下:
刪除學員信息:
<delete id="deleteStudent" parameterType="StudentEntity">
DELETE FROM STUDENT_TBL WHERE STUDENT_ID = #{studentID}
</delete>
2.ResultMap
SQL映射xml文件是為了放置所有sql語句,需要定義一個workspace,正常是介面類的路徑。SQL語句映射文件寫好後,需要在MyBatis配置文件mappers標簽中引用。
舉例如下:
<mappers>
<mapper resource="cn/te/ninixie/manager/data/mappers/UserMapper.xml" />
<mapper resource="cn/te/ninixie/manager/data/mappers/StudentMapper.xml" />
<mapper resource="cn/te/ninixie/manager/data/mappers/ClassMapper.xml" />
<mapper resource="cn/te/ninixie/manager/data/mappers/TeacherMapper.xml" />
</mappers>
當Java介面與xml文件在一個相對路徑下,那麼MyBaits配置文件的napper中可以不用聲明。
ResultMaps的作用,就是簡單的語句而不需要多餘的結果映射,更多復雜的語句,除了只要一些絕對必須的語句描述關系以外,就不需要其它的了。
resultMap屬性:type為java實體類;id為此resultMap的標識。
resultMap可以設置的映射:
2.1 constructor:用來將結果發射給一個實例化好的類的構造器
idArg_ID 參數:將結果集標記為ID,為了方便全局調用
arg –反射到構造器的通常結果
2.2 id結果,將結果集標記為ID,為了方便全局調用
2.3 result:反射到JavaBean的普通結果
2.4 association:復雜類型的結合,多個結果合成的類型
2.5 collection:復雜類型結合
2.6 resultMap的集合,也可以引用到其他
2.7 discriminator:使用一個結果值為了決定使用哪個結果集。
D. 如何當遠程的sql資料庫映射到本地
定時將SQLITE的數據導出為TXT文件,然後再導入SQL SERVER。 並無其它 什麼好方法。 安裝SQLITE驅動,將DB COPY到SQLSERVER機器上,用DTS OR JETSQL來導入
E. MyBatis sql映射文件疑問
其實沒有什麼區別,只不過是取值的方式不一樣罷了,
<resultMap id="wpResult" class="wp">
</resultMap>
配了一次就可以反復用,
Alias 需要在查詢語句里一個一個的as,你不覺得麻煩也可以用。
Alias最大的作用是聯表查詢的時候返回多個相同ID的時候可以改下名。不致於沖突報錯
F. 關於Mybatis SQL映射文件的問題
使用轉義符 < < ; >
G. ISA伺服器跟SQL伺服器的映射問題映射問題
在ISA server上作伺服器發布就可以
H. 學習SQL前需要學習什麼
呵呵,出入江湖的小夥子。
sql就是一種語言,與C和C++等一樣。但是它是針對資料庫的一種結構化查詢語言。
學習這個語言之前最好能對c或其他任何一種語言有所了解,但是sql語言和其他語言不一樣,包括寫法、語言的運行等等。
和離散數學裡面裡面的映射等連寫是非常密切的,只要努力,就能學好。重在理解。