📄 mssqlsource.java
字号:
/*
* Copyright 2006-2007 Queplix Corp.
*
* Licensed under the Queplix Public License, Version 1.1.1 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.queplix.com/solutions/commercial-open-source/queplix-public-license/
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package com.queplix.tools.fkchecker.kernel.sources;
import com.queplix.tools.fkchecker.kernel.types.ForeignKey;
import com.queplix.tools.fkchecker.kernel.types.KeyPair;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.Properties;
/**
* @author dmitry.antonov
*/
public class MsSqlSource extends AbstractDBSource {
private PreparedStatement tableNameGetter;
private PreparedStatement columnNameGetter;
public static ForeignKeysSource[] createSources(Properties properties) {
return new ForeignKeysSource[]{new MsSqlSource(properties)};
}
private MsSqlSource(Properties properties) {
super(properties);
}
protected void prepareParsing(Connection con) throws SQLException {
fkeys = con.createStatement().executeQuery("select so.name, sfk.fkeyid, " +
"sfk.rkeyid, sfk.fkey, sfk.rkey from sysforeignkeys sfk join sysobjects so on so.id=sfk.constid");
tableNameGetter = con.prepareStatement("select name from sysobjects where id=?");
columnNameGetter = con.prepareStatement("select name from syscolumns where id=? and colid=?");
}
protected boolean hasNext() throws SQLException {
return fkeys.next();
}
private String executeGetter(PreparedStatement ps, int... param) throws SQLException {
for (int i = 0; i < param.length; i++) {
ps.setInt(i+1, param[i]);
}
ResultSet rs = ps.executeQuery();
rs.next();
return rs.getString(1);
}
private KeyPair getKeyPair(int tableId, int columnId) throws SQLException {
return new KeyPair(executeGetter(tableNameGetter, tableId),
executeGetter(columnNameGetter, tableId, columnId));
}
protected ForeignKey nextForeignKey(Connection con) throws SQLException {
return new ForeignKey(fkeys.getString(1), getKeyPair(fkeys.getInt(2), fkeys.getInt(4)),
getKeyPair(fkeys.getInt(3), fkeys.getInt(5)));
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -