meine Sys/Db admin & Developper Notitzen - wer Rechtschreibfehler findet darf sie behalten ... my Sys/Db Admin and developper notes - I don't care about typos
Thursday, December 18, 2014
Visual Studio Find and Replace Regular Expressions / Suchen und Ersetzten mit Regulären Ausdrücken (regex)
auf gefunde Ausdrücke greift man mit z.b. \0 zu, \0 gibt den ersten gefunden Ausdruck zurück.
möchte man z.b. in allen DllImport Statements ,CallingConvention=CallingConvention.Cdecl hinzufügen, bsp:
[DllImport(DRIVER_DLL_NAME, EntryPoint = "is_StopLiveVideo")]
suchen: EntryPoint.*"
ersetzen: \0, CallingConvention=CallingConvention.Cdecl
Ergebnis:
[DllImport(DRIVER_DLL_NAME, EntryPoint = "is_StopLiveVideo",CallingConvention=CallingConvention.Cdecl)]
PInvokeStackImbalance was detected (c# / .net) - fix : CallingConvention.Cdecl
[DllImport(DRIVER_DLL_NAME, EntryPoint = "is_ClearSequence")] // is_ClearSequence
private static extern int is_ClearSequence(int hCam);
[DllImport(DRIVER_DLL_NAME, EntryPoint = "is_ClearSequence", CallingConvention = CallingConvention.Cdecl)] // is_ClearSequence
private static extern int is_ClearSequence(int hCam);
Tuesday, October 28, 2014
sql server tables unused space / unbenutzer Platz in Sql Server Tabellen, filesize / filegröße
--sql server tables unused space / unbenutzer Platz in Sql Server Tabellen:
SELECT
t.NAME AS TableName,
s.Name AS SchemaName,
p.rows AS RowCounts,
SUM(a.total_pages) * 8 AS TotalSpaceKB,
SUM(a.used_pages) * 8 AS UsedSpaceKB,
(SUM(a.total_pages) - SUM(a.used_pages)) * 8 AS UnusedSpaceKB
FROM sys.tables t
INNER JOIN sys.indexes i ON t.OBJECT_ID = i.object_id
INNER JOIN sys.partitions p ON i.object_id = p.OBJECT_ID AND i.index_id = p.index_id
INNER JOIN sys.allocation_units a ON p.partition_id = a.container_id
LEFT OUTER JOIN sys.schemas s ON t.schema_id = s.schema_id
WHERE t.NAME NOT LIKE 'dt%' AND t.is_ms_shipped = 0 AND i.OBJECT_ID > 255
GROUP BY t.Name, s.Name, p.Rows
ORDER BY UnusedSpaceKB desc
--filegröße / filesize
SELECT DB_NAME(database_id) AS DatabaseName,
Name AS Logical_Name,
Physical_Name, (size*8)/1024 SizeMB
FROM sys.master_files
where right(physical_name,3)='mdf'
order by size desc
Thursday, August 28, 2014
bootrec (windows 10)
bootrec /fixmbr
bootrec /fixboot
bootrec /rebuildbcd
wichtig: bios bootdevice muß harddisk sein => boot von hd einstellen und bootmenu aufrufen um dann von install disk zu booten, dann obige commandos ausführen win server braucht keine extra partition bcdboot c:\windows /s c: ... kopiert boot files von c:\windows\Boot auf C:\Boot wenn HyperV nicht automatisch startet: bcdedit /set hypervisorlaunchtype Auto
bootrec /fixboot
bootrec /rebuildbcd
wichtig: bios bootdevice muß harddisk sein => boot von hd einstellen und bootmenu aufrufen um dann von install disk zu booten, dann obige commandos ausführen win server braucht keine extra partition bcdboot c:\windows /s c: ... kopiert boot files von c:\windows\Boot auf C:\Boot wenn HyperV nicht automatisch startet: bcdedit /set hypervisorlaunchtype Auto
Wednesday, August 27, 2014
windows server 2012 Disk management
Server Manager unterstützt scheinbar keine MBR Initialisation, daher:
power shell: Initialize-Disk 4 –PartitionStyle MBR
Thursday, August 21, 2014
TSQL if then
--simplest / einfach
if 1=1 Print 'Ja-Yes' else print 'nein-no'
--one begin End block
if 1=0
Begin
Print 'Ja-Yes'
End
else print 'nein-no'
--two ifs
if 1=0
Begin
Print '1:Ja-Yes'
End
else if 1=1 print '1:nein-no, 2:ja-yes' else print '1:nein-no, 2:nein-no'
Friday, August 08, 2014
vs2008 ssrs: Filter in "test1,test2,test3" not working in preview
the in clause is not working in preview, but on reportserver: I have a sharepoint datasource, and a dataset, which I filter in a table with th IN clause - doesn't display any matches, but when I deploy it is working
Sunday, August 03, 2014
einfache / simple cte (common table expression)
with cte as (
select Year(GETDATE())*10000+MONTH(GetDate())*100+DAY(GetDate()) as intDate
)
select * from cte
Friday, August 01, 2014
ssrs display subreport without data / Unterbericht ohne Daten anzeigen
ein Unterbericht ohne Daten wird nicht angezeigt (wenn alle Datasets in diesem Report keine Zeilen haben, wird allerdings als eigenständiger Bericht angezeigt) => um ihn dennoch anzeigen einfach ein Dummy Dataset mit select 'dummy' as dummy einfügen, das hat immer eine Zeile und damit wird der Subreport angezeigt.
a subreport with all datasets having 0 rows isn't displayed (although as normal report is displayed) => add a dummy dataset which always returns a row to display (e.g. select 'dummy' as dummy )
ssrs gauge aggregate function report item
error / fehler:
The value expression for the gauge panel 'GaugePanel1' uses an aggregate function on a report item. Aggregate functions can be used only on report items contained in page headers and footers.
solution / lösung: change Indicator Properties / Values and States / States Measurement Unit from percentage to numeric
in Indicator Properties / Values and States / States Measurement Unit von Prozent auf numerisch ändern
The value expression for the gauge panel 'GaugePanel1' uses an aggregate function on a report item. Aggregate functions can be used only on report items contained in page headers and footers.
solution / lösung: change Indicator Properties / Values and States / States Measurement Unit from percentage to numeric
in Indicator Properties / Values and States / States Measurement Unit von Prozent auf numerisch ändern
Thursday, July 24, 2014
ssrs: vs2008 vorschau fehler / visual stuido 2008 preview error
sometimes gauge panels with 3 traffic light indicators shows in visual stuidio 2008 preview all three lights on, although it should only show one - when deploying, and showing same data, only one traffic light of three is on, as it should be ...
manchmal werden bei einem Gauge Panel mit 3 Ampel Indikatoren in der Visual Studio Vorschau alle 3 Ampellichter zugleich angezeigt - obowhl immer nur eines "leuchten" sollte. Wenn derselbe Report deployed wird und mit denselben Daten aufgerufen wird, wird korrekt nur ein Ampellicht (rot/grün/gelb) angezeigt ...
ssrs Tabelle mit nur Gruppierungszeilen ohne Details
eine neue Tabelle hat standardmäßig nur eine Zeile, die der Detailsgruppe "Detail1" zugeordnet ist. Geht man nun auf die Eigenschaften von "Details1" und fügt eine Gruppierung hinzu, verschwinden die waagrechten Detailszeilenzeichen und eine reine Gruppierungszeile entsteht (
sql server reporting services ssrs: transformation scope for state indicator must be specified
see property page of indicater scope property: e.g.: Scope=tablix1
ssrs not showing table
some grouping trouble can lead to not showing table at all - solution: delete group or check it
Monday, June 30, 2014
SSRS 2008 Dataset Filter
SSRS 2008 Dataset Filter can't include following expressions / können folgende Expressions nicht verwenden:
Aggregatsfunktionen (=First(...))
ReportItems
hypervisor not running: bcdedit /set hypervisorlaunchtype Auto
bcdedit /set hypervisorlaunchtype Auto
Tuesday, June 24, 2014
Reporting Services: getting values of textboxes with reportitems - werte aus Textboxen auslesen mittels ReportItems: =ReportItems!textbox3.Value
z.b. / eg.:
=ReportItems!textbox3.Value
ssrs 2008 shared sharepoint datasource doesn't work
using internal ssrs 2008 shared sharepoint datasource: no problem generating dataset
using same shared datasource, doesnt work
Wednesday, June 04, 2014
sql server: Check Constraints ein / ausschalten - switch on / off (z.b. Foreign Keys)
alter table tablename nocheck constraint all
alter table tablename check constraint all
Tuesday, June 03, 2014
Friday, May 30, 2014
Expression Textbox SSRS 2008 (Sql Server Reporting Services)
wenn bei einer TextBox in SSRS 2008 (Sql Server Reporting Services) mit rechter Maustaste im Context Menü "Expression" ausgegraut ist und auch nicht in TextBoxProperties General kein Value vorhanden ist, kann man durch Eingabe von z.b. ="X" in die Textbox direkt im Designer den Menüpunkt Expression bzw. die Value Eigenschaft wieder aktivieren.
OU (Organisation Unit) of ACtive Directory User
In Active Directory Users and COmputers: Menu View / Advanced Features
=> USer Prperties Show Tab Object, There you finde the Canonical Name of object
Friday, March 28, 2014
SSRS Ampeln (KPI) in VS2008 BI
Manchmal "leuchten" alle Ampeln (trotz Gegenteiliger Bedingungen) eines SSRS Reports im Preview des VS2008 Business Intelligence Studios, dann hilft es das Visual Studio zu schießen und neu zu öffnen.
Tuesday, March 25, 2014
Bindingnavigator manual Delete
BindingNavigator.DeleteItem = null; //manual Delete
this.bindingNavigatorDeleteItem.Click += new System.EventHandler(this.bindingNavigatorDeleteItem_Click);
private void bindingNavigatorDeleteItem_Click(object sender, EventArgs e)
{
if (DialogResult.Yes == MessageBox.Show("Wirklich löschen / Sure to delete ?", "Confirm / Bestätigen", MessageBoxButtons.YesNo))
{
bindingsource.RemoveCurrent();
}
}
Monday, March 24, 2014
sql server: restore many transactionlogs
example of restoring sql server transaction logs to a full backup:
beispiel einiger Befehlszielen um transaktionslogs wiederherzustellen:
RESTORE LOG [CrmBak] FROM DISK = N'E:\SqlServerBackup\CRM\CRM_backup_2014_01_01_230431_6398282.trn' WITH FILE = 1, NORECOVERY, NOUNLOAD, STATS = 10
RESTORE LOG [CrmBak] FROM DISK = N'E:\SqlServerBackup\CRM\CRM_backup_2014_01_02_230438_1759387.trn' WITH FILE = 1, NORECOVERY, NOUNLOAD, STATS = 10
RESTORE LOG [CrmBak] FROM DISK = N'E:\SqlServerBackup\CRM\CRM_backup_2014_01_03_230429_5963993.trn' WITH FILE = 1, NORECOVERY, NOUNLOAD, STATS = 10
to generate the restore command lines I used commandline: dir >dir.txt then with notepad++ I removed the date /time columns by pressing alt+marking with mouse, then used edit/Column editor to insert restore.... before the filename and ' WITH FILE=1 ... after the filename
um die Restore Befehle zu erzeugen, verwendetete ich den DOS BEfehel DIR: dir> dir.txt dann mit notepadd++ mit gedrückter alt taste mit der maus die unerwünschten spalten markeiren und löschen, dann mit edit / Column editor fügte ich vor dem dateinamen restore ... und nach dem DAteinamen 'WITH FILE=1 ... hinzu
wenn ein transaktionslog fehlt oder das zugrundeliegende full backup nicht in den Zeitraum des transaktionslogs fällt erhält man: Meldung 4305, Ebene 16, Status 1, Zeile 1 Das Protokoll in diesem Sicherungssatz beginnt bei LSN 29111000000034100001. Diese liegt für eine Anwendung auf die Datenbank nicht weit genug zurück. Eine frühere Protokollsicherung, die LSN 29015000000200600001 einschließt, kann wiederhergestellt werden. Meldung 3013, Ebene 16, Status 1, Zeile 1 RESTORE LOG wird fehlerbedingt beendet.
RESTORE LOG [CrmBak] FROM DISK = N'E:\SqlServerBackup\CRM\CRM_backup_2014_01_01_230431_6398282.trn' WITH FILE = 1, NORECOVERY, NOUNLOAD, STATS = 10
RESTORE LOG [CrmBak] FROM DISK = N'E:\SqlServerBackup\CRM\CRM_backup_2014_01_02_230438_1759387.trn' WITH FILE = 1, NORECOVERY, NOUNLOAD, STATS = 10
RESTORE LOG [CrmBak] FROM DISK = N'E:\SqlServerBackup\CRM\CRM_backup_2014_01_03_230429_5963993.trn' WITH FILE = 1, NORECOVERY, NOUNLOAD, STATS = 10
to generate the restore command lines I used commandline: dir >dir.txt then with notepad++ I removed the date /time columns by pressing alt+marking with mouse, then used edit/Column editor to insert restore.... before the filename and ' WITH FILE=1 ... after the filename
um die Restore Befehle zu erzeugen, verwendetete ich den DOS BEfehel DIR: dir> dir.txt dann mit notepadd++ mit gedrückter alt taste mit der maus die unerwünschten spalten markeiren und löschen, dann mit edit / Column editor fügte ich vor dem dateinamen restore ... und nach dem DAteinamen 'WITH FILE=1 ... hinzu
wenn ein transaktionslog fehlt oder das zugrundeliegende full backup nicht in den Zeitraum des transaktionslogs fällt erhält man: Meldung 4305, Ebene 16, Status 1, Zeile 1 Das Protokoll in diesem Sicherungssatz beginnt bei LSN 29111000000034100001. Diese liegt für eine Anwendung auf die Datenbank nicht weit genug zurück. Eine frühere Protokollsicherung, die LSN 29015000000200600001 einschließt, kann wiederhergestellt werden. Meldung 3013, Ebene 16, Status 1, Zeile 1 RESTORE LOG wird fehlerbedingt beendet.
Tuesday, March 18, 2014
Sql Server TSQL Script: Backup ALL Databases (foult tolreant / Fehlertolerant)
--TODO: Enter Profilename and Email ADress at last statement
DECLARE @name VARCHAR(50) -- database name
DECLARE @path VARCHAR(256) -- path for backup files
DECLARE @fileName VARCHAR(256) -- filename for backup
DECLARE @fileDate VARCHAR(20) -- used for file name
DECLARE @FEHLER VARCHAR(MAX)
DECLARE @MSG VARCHAR(MAX)
SET @path = 'F:\Backup\'
SET @Msg=''
SELECT @fileDate = CONVERT(VARCHAR(20),GETDATE(),112)
DECLARE db_cursor CURSOR FOR
SELECT name
FROM MASTER.dbo.sysdatabases
WHERE name NOT IN ('master','model','msdb','tempdb')
OPEN db_cursor
FETCH NEXT FROM db_cursor INTO @name
WHILE @@FETCH_STATUS = 0
BEGIN
SET @fileName = @path + @name + '_' + @fileDate + '.BAK'
BEGIN TRY
print 'BACKUP DATABASE '+@name+' TO DISK = '+@fileName;
BACKUP DATABASE @name TO DISK = @fileName
END TRY
BEGIN CATCH
set @Fehler= 'Error: BACKUP DATABASE '+@name+' TO DISK = '+@fileName
print @Fehler
set @MSG=@MSG+@Fehler
END CATCH
FETCH NEXT FROM db_cursor INTO @name
END
CLOSE db_cursor
DEALLOCATE db_cursor
--SEND Mail - use SSMS Management DatabaseMAil right click Send Testmail to get Profilename and test mail (and set up if needed
EXEC msdb.dbo.sp_send_dbmail
@profile_name = 'ProfileName',
@recipients = 'x@y.z',
@body = 'Backup Bericht SQLServer (wenn leer keine Fehler)',
@subject = @MSG ;
Thursday, March 13, 2014
create sql server login when not exists
if (SELECT SUSER_ID('test')) is null
begin
create login test with password='pwd'
end
Tuesday, March 11, 2014
disk queue length - Festplatten Warteschlange
In Windows resource Monitor, the disk queue length Counter should be lower then 2, if ist greater then 5 there is a serious Problem.
experience:
coping large amount of mixed files: disk queue length 1-2
coping large file on same disk: disk queue length 2-5
idle: 0
hyperV Server with raid 10, 13 virtual machines: disk queue length 1
Thursday, March 06, 2014
Vsiaul Studio 2008 + Team Foundation Server 2010
1. SP1 für VS2008 installieren (wurde TeamFoundationExplorer nach SP1 installation installiert muss SP1 Setup nochmals ausgeführt werden.)
[HKEY_CURRENT_USER\Software\Microsoft\VisualStudio\9.0\TeamFoundation\Instances\tfs01]
"Uri"="http://tfs01:8080/tfs""Type"=dword:00000000
[HKEY_CURRENT_USER\Software\Microsoft\VisualStudio\9.0\TeamFoundation\Instances\tfs01\Collections]
[HKEY_CURRENT_USER\Software\Microsoft\VisualStudio\9.0\TeamFoundation\Instances\tfs01\Collections\DefaultCollection]
"Uri"="http://tfs01:8080/tfs/defaultcollection""Type"=dword:00000001
Desktop Symbole ohne Admin Rechte verschieben
Als normaler Benutzer darf man
Desktop Symbole, die man nicht selbst angelegt hat, nicht löschen oder
verschieben. Damit das doch geht, einfach vollzugriff auf
C:\Users\Public\Desktop (bzw %public%\desktop) setzen, z.b. der Users group des
lokalen Rechners oder gleich den Domain Benutzern Vollzugriff geben:
Wednesday, February 26, 2014
creating Table on secondary filegroup on sql server / eine Tabelle in der zweiten Filegroup anlegen am Sql Server
angenommen die Datenbank
asuming the database has a filegroup named "secondary":
create table tSecondary
(
Id integer
)
on 'Secondary'
asuming the database has a filegroup named "secondary":
create table tSecondary
(
Id integer
)
on 'Secondary'
windows username, hostname, domainname by cmd (commandline)
benutzername / username:
echo %username%
or /oder
whoami
rechnername / hostname:
hostname
domainname:
echo %userdomain%
or / oder
systeminfo
echo %username%
or /oder
whoami
rechnername / hostname:
hostname
domainname:
echo %userdomain%
or / oder
systeminfo
Tuesday, February 11, 2014
Webservice for / für sharepoint List
sharepint List Adress: myserver/Intranet/mysite/Lists/mylist/Allitems.aspx
Webservice Adress: myserver/Intranet/mysite/_vti_bin/Lists.asmx
Webservice Adress: myserver/Intranet/mysite/_vti_bin/Lists.asmx
Thursday, February 06, 2014
show row numbers in Visual Studio / Zeilenzahlen in VS anzeigen
Tools/Options
TextEditor/AllLanguages
TextEditor/AllLanguages
Tuesday, February 04, 2014
sql server datenbank offline nehmen / take database offline / verbindungen lsöchen / kill connections
use master
go
ALTER DATABASE GBOv2_Reports_Test
SET OFFLINE WITH ROLLBACK IMMEDIATE
GO
alle Verbindungen zu einer db killen / delete all Connections to a db
declare @kill varchar(8000) = '';
select @kill=@kill+'kill '+convert(varchar(5),spid)+';'
from master..sysprocesses
where dbid=db_id('GBOv2_Reports_Test');
exec (@kill);
-- Show all processes of SQL Server / alle processe (Verbindungen) des SQL Servers anzeigen
select * from master..sysprocesses
go
ALTER DATABASE GBOv2_Reports_Test
SET OFFLINE WITH ROLLBACK IMMEDIATE
GO
alle Verbindungen zu einer db killen / delete all Connections to a db
declare @kill varchar(8000) = '';
select @kill=@kill+'kill '+convert(varchar(5),spid)+';'
from master..sysprocesses
where dbid=db_id('GBOv2_Reports_Test');
exec (@kill);
-- Show all processes of SQL Server / alle processe (Verbindungen) des SQL Servers anzeigen
select * from master..sysprocesses
Sunday, February 02, 2014
windows 7 mbr reparieren - fixmbr - fdisk /fixmbr - bootrec.exe /fixmbr
In der Windows 7 wiederherstellungskonsole verwendet man bootrec.exe /fixmbr statt früher aus msdos fdsik /fixmbr
Thursday, January 30, 2014
linux ftp server vsftpd
feststellen ob der ftp Dämon läuft:
netstat -a | grep ftp
in etc/VSFTPD liegt das config file
in etc/ftpusers sind user aufgelistet, die kein ftp machen dürfen (z.b. root)
user sieht normalerweise sein home dir
netstat -a | grep ftp
in etc/VSFTPD liegt das config file
in etc/ftpusers sind user aufgelistet, die kein ftp machen dürfen (z.b. root)
user sieht normalerweise sein home dir
remote desktop
Allgemein
Version feststellen cat /etc/*-release
sudo reboot
sudo poweroff
sudo shutdown
Nano Texteditor
Select: ALT + M + A
Copy: ALT + 6
Paste: CTRL + U
Zeile ausschneiden: CRTL +K
SUCHEN: CRTL-W
Zeile ausschneiden: CRTL +K
SUCHEN: CRTL-W
User
user anzeigen: cat /etc/passwdbenutzer hinzufügen: sudo adduser BENUTZERNAME
Passwort ändern: sudo passwd BENUTZERNAME
Benutzer zu einer Gruppe hinzufügen: sudo usermod -aG gruppenname Username
gruppe hinzufügen: sudo groupadd www
Netzwerk
ifconfig
ftpclient: sudo apt-get ftp
ssh xxx.yyy.zzz.aaa -l loginname
ssh xxx.yyy.zzz.aaa -l loginname
Crontab (not crone)
alle einträge listen: crontab -l
edit bzw erstmalig erzeugen: crontab -e
*/1 * * * * $HOME/test.py >> test.log 2>&1
jede minute test.py starten und in test.log schreiben
test.py:
#!/usr/bin/env python
import time
print(time.strftime("%d.%m.%Y %H:%M:%S"))
Installierete Software
dpkp -l > pakete.txt
sudo apt-get update # Fetches the list of available updates
sudo apt-get upgrade # Strictly upgrades the current packages
sudo apt-get dist-upgrade # Installs updates (new ones)
Disk Partitionen
ls /dev/
ls /mnt/
mount
ls /mnt/
mount
mmcblk0 ... SdCard0
sda ... SolidDriveA (Hard Disk A)
sudo fdisk -l
sudo blkid -o list
df -h ... DiskFree -human readable
cat /proc/partitions
sudo fdisk /dev/mmcblk0
p ... list partition
q ... quit without writing
sudo fdisk /dev/mmcblk0
p ... list partition
q ... quit without writing
Dateien / Files
Datein mit rechte usw: ls -l
rechte: owner/gruppe/other
rechte: owner/gruppe/other
freier Speicherplatz auf den HDs: df -h
Dir anzeigen: ls
alle Dateien listen: ls -aDir anzeigen: ls
suchen: find / -Name ftp* sucht alle Dateien mit ftp
löschen: rm
kopieren von Bäumen (-r) ohne überschreiben existierender Dateien (-n) und Ausgabe der gerade kopierten Datei --verbose
cp --verbose -rn quelle ziel
Rechte anzeigen: ls-l (owner gruppe andere, username gruppenname )
chmod 774 datei
Owner ändern:
chown -c user:gruppe datei
zu anderem linux rechner kopieren:
scp myfile user@192.168.1.8:
standard Dirs:
1. / – Root
Every single file and directory starts from the root directory.
Only root user has write privilege under this directory.
Please note that /root is root user’s home directory, which is not same as /.
2. /bin – User Binaries
Contains binary executables.
Common linux commands you need to use in single-user modes are located under this directory.
Commands used by all the users of the system are located here.
For example: ps, ls, ping, grep, cp.
3. /sbin – System Binaries
Just like /bin, /sbin also contains binary executables.
But, the linux commands located under this directory are used typically by system aministrator, for system maintenance purpose.
For example: iptables, reboot, fdisk, ifconfig, swapon
4. /etc – Configuration Files
Contains configuration files required by all programs.
This also contains startup and shutdown shell scripts used to start/stop individual programs.
For example: /etc/resolv.conf, /etc/logrotate.conf
5. /dev – Device Files
Contains device files.
These include terminal devices, usb, or any device attached to the system.
For example: /dev/tty1, /dev/usbmon0
6. /proc – Process Information
Contains information about system process.
This is a pseudo filesystem contains information about running process. For example: /proc/{pid} directory contains information about the process with that particular pid.
This is a virtual filesystem with text information about system resources. For example: /proc/uptime
7. /var – Variable Files
var stands for variable files.
Content of the files that are expected to grow can be found under this directory.
This includes — system log files (/var/log); packages and database files (/var/lib); emails (/var/mail); print queues (/var/spool); lock files (/var/lock); temp files needed across reboots (/var/tmp);
8. /tmp – Temporary Files
Directory that contains temporary files created by system and users.
Files under this directory are deleted when system is rebooted.
9. /usr – User Programs
Contains binaries, libraries, documentation, and source-code for second level programs.
/usr/bin contains binary files for user programs. If you can’t find a user binary under /bin, look under /usr/bin. For example: at, awk, cc, less, scp
/usr/sbin contains binary files for system administrators. If you can’t find a system binary under /sbin, look under /usr/sbin. For example: atd, cron, sshd, useradd, userdel
/usr/lib contains libraries for /usr/bin and /usr/sbin
/usr/local contains users programs that you install from source. For example, when you install apache from source, it goes under /usr/local/apache2
10. /home – Home Directories
Home directories for all users to store their personal files.
For example: /home/john, /home/nikita
11. /boot – Boot Loader Files
Contains boot loader related files.
Kernel initrd, vmlinux, grub files are located under /boot
For example: initrd.img-2.6.32-24-generic, vmlinuz-2.6.32-24-generic
12. /lib – System Libraries
Contains library files that supports the binaries located under /bin and /sbin
Library filenames are either ld* or lib*.so.*
For example: ld-2.11.1.so, libncurses.so.5.7
13. /opt – Optional add-on Applications
opt stands for optional.
Contains add-on applications from individual vendors.
add-on applications should be installed under either /opt/ or /opt/ sub-directory.
14. /mnt – Mount Directory
Temporary mount directory where sysadmins can mount filesystems.
15. /media – Removable Media Devices
Temporary mount directory for removable devices.
For examples, /media/cdrom for CD-ROM; /media/floppy for floppy drives; /media/cdrecorder for CD writer
16. /srv – Service Data
srv stands for service.
Contains server specific services related data.
For example, /srv/cvs contains CVS related data.
Thursday, January 23, 2014
Webservice Proxy Klasse c# in Visual Stuido erzeugen
VS2008:
1) unter References add Service Referenc
2) unter Advanced Add Web Reference
3) Url eingeben (wdsl) => zeigt Servicenamen und Methodennamen an, schlägt Web Reference Name vor, diesen anpassen
4) es wird Code unter WebReferences\WebReferenceName\Reference.cs erzeugt, die wichtigste Klasse heißt genauso wie das Service (unter 3 angezeigt)
1) unter References add Service Referenc
2) unter Advanced Add Web Reference
3) Url eingeben (wdsl) => zeigt Servicenamen und Methodennamen an, schlägt Web Reference Name vor, diesen anpassen
4) es wird Code unter WebReferences\WebReferenceName\Reference.cs erzeugt, die wichtigste Klasse heißt genauso wie das Service (unter 3 angezeigt)
Tuesday, January 21, 2014
Wednesday, January 15, 2014
oracle simple package
Header:
CREATE OR REPLACE
PACKAGE PA_PDB_UTIL AS
PROCEDURE P_PDB_SeekId (inId IN VARCHAR2, ret OUT integer);
END PA_PDB_UTIL;
Body:
CREATE OR REPLACE
PACKAGE BODY PA_PDB_UTIL AS
PROCEDURE P_PDB_SeekId (inId IN VARCHAR2, ret OUT integer) AS
BEGIN
dbms_output.put_line ('beginn!');
dbms_output.put_line (inPannenId);
select count(*) into ret from test where Id=inId;
dbms_output.put_line (ret);
dbms_output.put_line ('End');
NULL;
END P_PDB_SeekId;
END PA_PDB_UTIL;
Testen mit:
set serveroutput on;
declare ret integer;
begin
PA_PDB_UTIL.P_PDB_SeekPannenId('test', ret);
end;
CREATE OR REPLACE
PACKAGE PA_PDB_UTIL AS
PROCEDURE P_PDB_SeekId (inId IN VARCHAR2, ret OUT integer);
END PA_PDB_UTIL;
Body:
CREATE OR REPLACE
PACKAGE BODY PA_PDB_UTIL AS
PROCEDURE P_PDB_SeekId (inId IN VARCHAR2, ret OUT integer) AS
BEGIN
dbms_output.put_line ('beginn!');
dbms_output.put_line (inPannenId);
select count(*) into ret from test where Id=inId;
dbms_output.put_line (ret);
dbms_output.put_line ('End');
NULL;
END P_PDB_SeekId;
END PA_PDB_UTIL;
Testen mit:
set serveroutput on;
declare ret integer;
begin
PA_PDB_UTIL.P_PDB_SeekPannenId('test', ret);
end;
Tuesday, January 14, 2014
oracle top cpu time sql
SET pages 3000
SET LINES 120
SET trimspool ON
SET trimout ON
COLUMNS sql_text FORMAT a40 word_wrapped HEAD
'SQL|Text'
COLUMNS cpu_time
HEAD 'CPU|Time'
COLUMNS elapsed_time HEAD 'Elapsed|Time'
COLUMNS disk_reads HEAD
'Disk|Reads'
COLUMNS buffer_gets HEAD
'Buffer|Gets'
COLUMNS rows_processed HEAD 'Rows|Processed'
TTITLE 'SQL-Statements nach CPU-Nutzung'
SELECT * FROM
(SELECT sql_text,
cpu_time/1000000
cpu_time,
elapsed_time/1000000
elapsed_time,
disk_reads,
buffer_gets,
rows_processed
FROM
v$sqlarea Where SQL_Text Like '%T_PDB_%'
ORDER BY cpu_time DESC
)
WHERE rownum <=25;
In welcher Tabelle ist die Spalte namens ? Where is column (in which table)
oracle:
select * from user_tab_columns where table_name like 'T_PDB%' and Column_NAME like '%PRO%';
sql-server:
select c.name,t.name from sys.columns c join sys.tables t on c.object_id=t.object_id where c.name like 'Bem%'
select * from user_tab_columns where table_name like 'T_PDB%' and Column_NAME like '%PRO%';
sql-server:
select c.name,t.name from sys.columns c join sys.tables t on c.object_id=t.object_id where c.name like 'Bem%'
Access Query 2 Oracle IIF
IIF ... CASE
f.bla AS S_Bla,
(
CASE TO_CHAR(Reparaturdatum, 'YYYY')
WHEN '1899'
THEN '-'
ELSE TO_CHAR(Reparaturdatum, 'DD.MM.YYYY')
END) AS S_RDatum,
f.Fallzaehler AS S_Fallzaehler,
NZ ... NVL
f.bla AS S_Bla,
(
CASE TO_CHAR(Reparaturdatum, 'YYYY')
WHEN '1899'
THEN '-'
ELSE TO_CHAR(Reparaturdatum, 'DD.MM.YYYY')
END) AS S_RDatum,
f.Fallzaehler AS S_Fallzaehler,
NZ ... NVL
Monday, January 13, 2014
access auf ODBC Backend umstellen - move from Access to ODBC Backend
Beim Umstellen eines reinen Access Backends auf ein ODBC Backend (z.b. Oracle over ODBC) gibt es folgendes zu beachten:
1) recordset Find Operationen sind extrem langsam, da zuerst die ganze Tabelle in den Access Speicher geladen wird und dort dann gesucht wird. Besser das Recordset gleich mit der richtigen WHERE Bedingung aufmachen:
Set rs= New ADODB.Recordset
rs.Open "select * from mytable where ID='" & 923 & "'", connection, adOpenKeyset, adLockReadOnly
statt:
rs.Find "ID= '" & 923 & "'", , adSearchForward, adBookmarkFirst
2) wenn man Sätze mit rs.AddNew / rs.Update hinzufügt, so werden diese zwar im Backend hinzugefügt aber nicht im Recordset = nochmal nachladen
1) recordset Find Operationen sind extrem langsam, da zuerst die ganze Tabelle in den Access Speicher geladen wird und dort dann gesucht wird. Besser das Recordset gleich mit der richtigen WHERE Bedingung aufmachen:
Set rs= New ADODB.Recordset
rs.Open "select * from mytable where ID='" & 923 & "'", connection, adOpenKeyset, adLockReadOnly
statt:
rs.Find "ID= '" & 923 & "'", , adSearchForward, adBookmarkFirst
2) wenn man Sätze mit rs.AddNew / rs.Update hinzufügt, so werden diese zwar im Backend hinzugefügt aber nicht im Recordset = nochmal nachladen
Thursday, January 09, 2014
enumerate enum
enum eAbgeschlossen
{
Abgeschlossen_Closed,
Alle_All,
NichAbgeschlossen_NotClosed
}
foreach (eAbgeschlossen e in Enum.GetValues(typeof(eAbgeschlossen)).Cast())
{
cbAbgeschlossenFilter.Items.Add(e.ToString()); //adding to Combobox
}
{
Abgeschlossen_Closed,
Alle_All,
NichAbgeschlossen_NotClosed
}
foreach (eAbgeschlossen e in Enum.GetValues(typeof(eAbgeschlossen)).Cast
{
cbAbgeschlossenFilter.Items.Add(e.ToString()); //adding to Combobox
}
The server encountered an error while creating Virtual Machine (Hyper V)
When creating a new virtual Machine on Hyper V Server (Windows 8, Server 2012) sometimes ths error occurs:
The server encountered an error while creating Virtual Machine
The operation failed.
An unexpected error occurred: Logon failure: the user has not been granted the requested logon type at this computer. (0x80070569).
Work around: Hyper-V Virtual Machine Management Service restart.
-----------------------------------------------------------------------------------------------------------
Beim Erzeugen einer neue Virtuellen Maschine am Hyper V Server (Windows 8, Windwos Server 2012) tritt manchmal folgender Fehler auf:
The server encountered an error while creating Virtual Machine
The operation failed.
An unexpected error occurred: Logon failure: the user has not been granted the requested logon type at this computer. (0x80070569).
Work Around: Hyper-V Virtual Machine Management Service restarten.
The server encountered an error while creating Virtual Machine
The operation failed.
An unexpected error occurred: Logon failure: the user has not been granted the requested logon type at this computer. (0x80070569).
Work around: Hyper-V Virtual Machine Management Service restart.
-----------------------------------------------------------------------------------------------------------
Beim Erzeugen einer neue Virtuellen Maschine am Hyper V Server (Windows 8, Windwos Server 2012) tritt manchmal folgender Fehler auf:
The server encountered an error while creating Virtual Machine
The operation failed.
An unexpected error occurred: Logon failure: the user has not been granted the requested logon type at this computer. (0x80070569).
Work Around: Hyper-V Virtual Machine Management Service restarten.
The trust relationship between this workstation and the primary domain failed
Wenn beim Login der Fehler
The trust relationship between this workstation and the primary domain failed
erscheint, einfach den Computer aus der Domäne nehmen (in eine Workgroup), neustarten und wieder in die Domäne hängen
Login Error:
The trust relationship between this workstation and the primary domain failed
remove the Computer from the domän (to a workgroup), restart and join the domain again
The trust relationship between this workstation and the primary domain failed
erscheint, einfach den Computer aus der Domäne nehmen (in eine Workgroup), neustarten und wieder in die Domäne hängen
Login Error:
The trust relationship between this workstation and the primary domain failed
remove the Computer from the domän (to a workgroup), restart and join the domain again
CRT ALT DEL Remote Desktop: CRT ALT END
Um CRT ALT DEL über Remote Desktop (RDS) zu schicken, verwende CRT-ALT_END
Tuesday, January 07, 2014
Entity Framework liest statt unterscheidlicher Datensätze mehrfach den gleichen aus
Wenn bei einer view der Primary Key fehlt, so liefert das Entity Framework eventuell immer den gleichen Datensatz.
Man muß dann einen künstlichen Primary Key scahffen, z.b. mittels
Man muß dann einen künstlichen Primary Key scahffen, z.b. mittels
IsNUll(ROW_NUMBER() OVER(ORDER BY Lastname, FirstName),-1) AS 'ID'
und andere Spalten, die als Primary Key herangezogen werden mit NullIf(keyKandidat,-1) als Kandidat für den Primary Key aussschließen. Dann die View im Model löschen und neu hinzufügen.
Subscribe to:
Posts (Atom)